@capacitor/android 5.7.7 → 5.7.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -144,23 +144,19 @@ var nativeBridge = (function (exports) {
144
144
  return { data: body, type: 'json' };
145
145
  };
146
146
  const CAPACITOR_HTTP_INTERCEPTOR = '/_capacitor_http_interceptor_';
147
- const CAPACITOR_HTTPS_INTERCEPTOR = '/_capacitor_https_interceptor_';
147
+ const CAPACITOR_HTTP_INTERCEPTOR_URL_PARAM = 'u';
148
148
  // TODO: export as Cap function
149
149
  const isRelativeOrProxyUrl = (url) => !url ||
150
150
  !(url.startsWith('http:') || url.startsWith('https:')) ||
151
- url.indexOf(CAPACITOR_HTTP_INTERCEPTOR) > -1 ||
152
- url.indexOf(CAPACITOR_HTTPS_INTERCEPTOR) > -1;
151
+ url.indexOf(CAPACITOR_HTTP_INTERCEPTOR) > -1;
153
152
  // TODO: export as Cap function
154
153
  const createProxyUrl = (url, win) => {
155
154
  var _a, _b;
156
155
  if (isRelativeOrProxyUrl(url))
157
156
  return url;
158
- const proxyUrl = new URL(url);
159
157
  const bridgeUrl = new URL((_b = (_a = win.Capacitor) === null || _a === void 0 ? void 0 : _a.getServerUrl()) !== null && _b !== void 0 ? _b : '');
160
- const isHttps = proxyUrl.protocol === 'https:';
161
- bridgeUrl.search = proxyUrl.search;
162
- bridgeUrl.hash = proxyUrl.hash;
163
- bridgeUrl.pathname = `${isHttps ? CAPACITOR_HTTPS_INTERCEPTOR : CAPACITOR_HTTP_INTERCEPTOR}/${encodeURIComponent(proxyUrl.host)}${proxyUrl.pathname}`;
158
+ bridgeUrl.pathname = CAPACITOR_HTTP_INTERCEPTOR;
159
+ bridgeUrl.searchParams.append(CAPACITOR_HTTP_INTERCEPTOR_URL_PARAM, url);
164
160
  return bridgeUrl.toString();
165
161
  };
166
162
  const initBridge = (w) => {
@@ -89,8 +89,13 @@ public class Bridge {
89
89
  public static final String CAPACITOR_FILE_START = "/_capacitor_file_";
90
90
  public static final String CAPACITOR_CONTENT_START = "/_capacitor_content_";
91
91
  public static final String CAPACITOR_HTTP_INTERCEPTOR_START = "/_capacitor_http_interceptor_";
92
+
93
+ /** @deprecated CAPACITOR_HTTPS_INTERCEPTOR_START is no longer required. All proxied requests are handled via CAPACITOR_HTTP_INTERCEPTOR_START instead */
94
+ @Deprecated
92
95
  public static final String CAPACITOR_HTTPS_INTERCEPTOR_START = "/_capacitor_https_interceptor_";
93
96
 
97
+ public static final String CAPACITOR_HTTP_INTERCEPTOR_URL_PARAM = "u";
98
+
94
99
  public static final int DEFAULT_ANDROID_WEBVIEW_VERSION = 60;
95
100
  public static final int MINIMUM_ANDROID_WEBVIEW_VERSION = 55;
96
101
  public static final int DEFAULT_HUAWEI_WEBVIEW_VERSION = 10;
@@ -30,7 +30,6 @@ import java.io.InputStream;
30
30
  import java.net.HttpURLConnection;
31
31
  import java.net.URL;
32
32
  import java.net.URLConnection;
33
- import java.net.URLDecoder;
34
33
  import java.nio.charset.StandardCharsets;
35
34
  import java.util.ArrayList;
36
35
  import java.util.HashMap;
@@ -172,13 +171,7 @@ public class WebViewLocalServer {
172
171
  public WebResourceResponse shouldInterceptRequest(WebResourceRequest request) {
173
172
  Uri loadingUrl = request.getUrl();
174
173
 
175
- if (
176
- null != loadingUrl.getPath() &&
177
- (
178
- loadingUrl.getPath().startsWith(Bridge.CAPACITOR_HTTP_INTERCEPTOR_START) ||
179
- loadingUrl.getPath().startsWith(Bridge.CAPACITOR_HTTPS_INTERCEPTOR_START)
180
- )
181
- ) {
174
+ if (null != loadingUrl.getPath() && loadingUrl.getPath().startsWith(Bridge.CAPACITOR_HTTP_INTERCEPTOR_START)) {
182
175
  Logger.debug("Handling CapacitorHttp request: " + loadingUrl);
183
176
  try {
184
177
  return handleCapacitorHttpRequest(request);
@@ -259,16 +252,7 @@ public class WebViewLocalServer {
259
252
  }
260
253
 
261
254
  private WebResourceResponse handleCapacitorHttpRequest(WebResourceRequest request) throws IOException {
262
- boolean isHttps =
263
- request.getUrl().getPath() != null && request.getUrl().getPath().startsWith(Bridge.CAPACITOR_HTTPS_INTERCEPTOR_START);
264
-
265
- String urlString = request
266
- .getUrl()
267
- .toString()
268
- .replace(bridge.getLocalUrl(), isHttps ? "https:/" : "http:/")
269
- .replace(Bridge.CAPACITOR_HTTP_INTERCEPTOR_START, "")
270
- .replace(Bridge.CAPACITOR_HTTPS_INTERCEPTOR_START, "");
271
- urlString = URLDecoder.decode(urlString, "UTF-8");
255
+ String urlString = request.getUrl().getQueryParameter(Bridge.CAPACITOR_HTTP_INTERCEPTOR_URL_PARAM);
272
256
  URL url = new URL(urlString);
273
257
  JSObject headers = new JSObject();
274
258
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@capacitor/android",
3
- "version": "5.7.7",
3
+ "version": "5.7.8",
4
4
  "description": "Capacitor: Cross-platform apps with JavaScript and the web",
5
5
  "homepage": "https://capacitorjs.com",
6
6
  "author": "Ionic Team <hi@ionic.io> (https://ionic.io)",