OpenDelta: move from apache http to UrlConnection

Apache HTTP client is deprecated as of M.
UrlConnection is lightweight, more efficient api it also
minimizes power consumption (ref. Android 6.0 changes).

Change-Id: Ic5907d8d33c302e7faad9d08b2c0f9f58f12e66e
This commit is contained in:
cherifyass 2016-02-28 21:51:21 +01:00
parent ac1f262a8f
commit 6454599803
2 changed files with 101 additions and 80 deletions

View File

@ -7,7 +7,6 @@ LOCAL_PRIVILEGED_MODULE := true
LOCAL_SRC_FILES := $(call all-java-files-under, src) LOCAL_SRC_FILES := $(call all-java-files-under, src)
LOCAL_JAVA_LIBRARIES := org.apache.http.legacy
LOCAL_JNI_SHARED_LIBRARIES := libopendelta LOCAL_JNI_SHARED_LIBRARIES := libopendelta
LOCAL_REQUIRED_MODULES := libopendelta LOCAL_REQUIRED_MODULES := libopendelta

View File

@ -21,6 +21,7 @@
package eu.chainfire.opendelta; package eu.chainfire.opendelta;
import java.io.ByteArrayOutputStream;
import java.io.File; import java.io.File;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
@ -32,6 +33,8 @@ import java.io.UnsupportedEncodingException;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.math.BigInteger; import java.math.BigInteger;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import java.net.URL;
import java.nio.charset.StandardCharsets;
import java.security.MessageDigest; import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException; import java.security.NoSuchAlgorithmException;
import java.util.ArrayList; import java.util.ArrayList;
@ -39,17 +42,8 @@ import java.util.Iterator;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;
import java.util.Date; import java.util.Date;
import javax.net.ssl.HttpsURLConnection;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.params.BasicHttpParams;
import org.apache.http.params.HttpConnectionParams;
import org.apache.http.params.HttpParams;
import org.apache.http.protocol.HTTP;
import org.apache.http.util.EntityUtils;
import org.json.JSONArray; import org.json.JSONArray;
import org.json.JSONException; import org.json.JSONException;
import org.json.JSONObject; import org.json.JSONObject;
@ -77,6 +71,7 @@ import android.os.StatFs;
import android.os.SystemClock; import android.os.SystemClock;
import android.preference.PreferenceManager; import android.preference.PreferenceManager;
import android.text.TextUtils; import android.text.TextUtils;
import eu.chainfire.opendelta.BatteryState.OnBatteryStateListener; import eu.chainfire.opendelta.BatteryState.OnBatteryStateListener;
import eu.chainfire.opendelta.DeltaInfo.ProgressListener; import eu.chainfire.opendelta.DeltaInfo.ProgressListener;
import eu.chainfire.opendelta.NetworkState.OnNetworkStateListener; import eu.chainfire.opendelta.NetworkState.OnNetworkStateListener;
@ -86,7 +81,7 @@ import eu.chainfire.opendelta.ScreenState.OnScreenStateListener;
public class UpdateService extends Service implements OnNetworkStateListener, public class UpdateService extends Service implements OnNetworkStateListener,
OnBatteryStateListener, OnScreenStateListener, OnBatteryStateListener, OnScreenStateListener,
OnWantUpdateCheckListener, OnSharedPreferenceChangeListener { OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
private static final int HTTP_SOCKET_TIMEOUT = 30000; private static final int HTTP_READ_TIMEOUT = 30000;
private static final int HTTP_CONNECTION_TIMEOUT = 30000; private static final int HTTP_CONNECTION_TIMEOUT = 30000;
public static void start(Context context) { public static void start(Context context) {
@ -550,32 +545,50 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
notificationManager.cancel(NOTIFICATION_ERROR); notificationManager.cancel(NOTIFICATION_ERROR);
} }
private byte[] downloadUrlMemory(String url) { private HttpsURLConnection setupHttpsRequest(String urlStr){
Logger.d("download: %s", url); URL url;
HttpsURLConnection urlConnection = null;
try { try {
HttpParams params = new BasicHttpParams(); url = new URL(urlStr);
HttpConnectionParams.setConnectionTimeout(params, HTTP_CONNECTION_TIMEOUT); urlConnection = (HttpsURLConnection) url.openConnection();
HttpConnectionParams.setSoTimeout(params, HTTP_SOCKET_TIMEOUT); urlConnection.setConnectTimeout(HTTP_CONNECTION_TIMEOUT);
HttpClient client = new DefaultHttpClient(params); urlConnection.setReadTimeout(HTTP_READ_TIMEOUT);
HttpGet request = new HttpGet(url); urlConnection.setRequestMethod("GET");
HttpResponse response = client.execute(request); urlConnection.setDoInput(true);
int code = response.getStatusLine().getStatusCode(); urlConnection.connect();
if (code != HttpStatus.SC_OK) { int code = urlConnection.getResponseCode();
if (code != HttpsURLConnection.HTTP_OK) {
Logger.d("response: %d", code); Logger.d("response: %d", code);
return null; return null;
} }
int len = (int) response.getEntity().getContentLength(); return urlConnection;
if ((len >= 0) && (len < 1024 * 1024)) { } catch (Exception e) {
byte[] ret = new byte[len]; Logger.i("Failed to connect to server");
InputStream in = response.getEntity().getContent();
int pos = 0;
while (pos < len) {
int r = in.read(ret, pos, len - pos);
pos += r;
if (r <= 0)
return null; return null;
} }
return ret; }
private byte[] downloadUrlMemory(String url) {
Logger.d("download: %s", url);
HttpsURLConnection urlConnection = null;
try {
urlConnection = setupHttpsRequest(url);
if(urlConnection == null) {
return null;
}
int len = urlConnection.getContentLength();
if ((len >= 0) && (len < 1024 * 1024)) {
InputStream is = urlConnection.getInputStream();
int byteInt;
ByteArrayOutputStream byteArray = new ByteArrayOutputStream();
while((byteInt = is.read()) >= 0){
byteArray.write(byteInt);
}
return byteArray.toByteArray();
} }
return null; return null;
} catch (Exception e) { } catch (Exception e) {
@ -583,34 +596,47 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
// drops, etc. Just log it in debugging mode. // drops, etc. Just log it in debugging mode.
Logger.ex(e); Logger.ex(e);
return null; return null;
} finally {
if (urlConnection != null) {
urlConnection.disconnect();
}
} }
} }
private String downloadUrlMemoryAsString(String url) { private String downloadUrlMemoryAsString(String url) {
Logger.d("download: %s", url); Logger.d("download: %s", url);
HttpsURLConnection urlConnection = null;
try { try {
HttpParams params = new BasicHttpParams(); urlConnection = setupHttpsRequest(url);
HttpConnectionParams.setConnectionTimeout(params, HTTP_CONNECTION_TIMEOUT); if(urlConnection == null){
HttpConnectionParams.setSoTimeout(params, HTTP_SOCKET_TIMEOUT);
HttpClient client = new DefaultHttpClient(params);
HttpGet request = new HttpGet(url);
HttpResponse response = client.execute(request);
int code = response.getStatusLine().getStatusCode();
if (code != HttpStatus.SC_OK) {
Logger.d("response: %d", code);
return null; return null;
} }
String responseBody = EntityUtils.toString(response.getEntity(),
HTTP.UTF_8); InputStream is = urlConnection.getInputStream();
return responseBody; ByteArrayOutputStream byteArray = new ByteArrayOutputStream();
} catch (UnknownHostException e) { int byteInt;
Logger.i("Failed to connect to download server");
while((byteInt = is.read()) >= 0){
byteArray.write(byteInt);
}
byte[] bytes = byteArray.toByteArray();
if(bytes == null){
return null; return null;
}
String responseBody = new String(bytes, StandardCharsets.UTF_8);
return responseBody;
} catch (Exception e) { } catch (Exception e) {
// Download failed for any number of reasons, timeouts, connection // Download failed for any number of reasons, timeouts, connection
// drops, etc. Just log it in debugging mode. // drops, etc. Just log it in debugging mode.
Logger.ex(e); Logger.ex(e);
return null; return null;
} finally {
if (urlConnection != null) {
urlConnection.disconnect();
}
} }
} }
@ -618,6 +644,7 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
DeltaInfo.ProgressListener progressListener) { DeltaInfo.ProgressListener progressListener) {
Logger.d("download: %s", url); Logger.d("download: %s", url);
HttpsURLConnection urlConnection = null;
MessageDigest digest = null; MessageDigest digest = null;
if (matchMD5 != null) { if (matchMD5 != null) {
try { try {
@ -630,24 +657,18 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
if (f.exists()) if (f.exists())
f.delete(); f.delete();
try { try {
HttpParams params = new BasicHttpParams(); urlConnection = setupHttpsRequest(url);
HttpConnectionParams.setConnectionTimeout(params, HTTP_CONNECTION_TIMEOUT); if(urlConnection == null){
HttpConnectionParams.setSoTimeout(params, HTTP_SOCKET_TIMEOUT);
HttpClient client = new DefaultHttpClient(params);
HttpGet request = new HttpGet(url);
HttpResponse response = client.execute(request);
int code = response.getStatusLine().getStatusCode();
if (code != HttpStatus.SC_OK) {
Logger.d("response: %d", code);
return false; return false;
} }
long len = (int) response.getEntity().getContentLength(); long len = urlConnection.getContentLength();
long recv = 0; long recv = 0;
if ((len > 0) && (len < 4L * 1024L * 1024L * 1024L)) { if ((len > 0) && (len < 4L * 1024L * 1024L * 1024L)) {
byte[] buffer = new byte[262144]; byte[] buffer = new byte[262144];
InputStream is = response.getEntity().getContent(); InputStream is = urlConnection.getInputStream();
FileOutputStream os = new FileOutputStream(f, false); FileOutputStream os = new FileOutputStream(f, false);
try { try {
int r; int r;
@ -688,6 +709,10 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
// drops, etc. Just log it in debugging mode. // drops, etc. Just log it in debugging mode.
Logger.ex(e); Logger.ex(e);
return false; return false;
} finally {
if (urlConnection != null) {
urlConnection.disconnect();
}
} }
} }
@ -695,6 +720,7 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
String matchMD5) { String matchMD5) {
Logger.d("download: %s", url); Logger.d("download: %s", url);
HttpsURLConnection urlConnection = null;
MessageDigest digest = null; MessageDigest digest = null;
long len = 0; long len = 0;
if (matchMD5 != null) { if (matchMD5 != null) {
@ -708,21 +734,15 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
if (f.exists()) if (f.exists())
f.delete(); f.delete();
try { try {
updateState(STATE_ACTION_DOWNLOADING, 0f, 0L, 0L, f.getName(), null); updateState(STATE_ACTION_DOWNLOADING, 0f, 0L, 0L, f.getName(), null);
urlConnection = setupHttpsRequest(url);
HttpParams params = new BasicHttpParams(); if(urlConnection == null){
HttpConnectionParams.setConnectionTimeout(params, HTTP_CONNECTION_TIMEOUT);
HttpConnectionParams.setSoTimeout(params, HTTP_SOCKET_TIMEOUT);
HttpClient client = new DefaultHttpClient(params);
HttpGet request = new HttpGet(url);
HttpResponse response = client.execute(request);
int code = response.getStatusLine().getStatusCode();
if (code != HttpStatus.SC_OK) {
Logger.d("response: %d", code);
return false; return false;
} }
len = (int) response.getEntity().getContentLength();
len = urlConnection.getContentLength();
updateState(STATE_ACTION_DOWNLOADING, 0f, 0L, len, f.getName(), null); updateState(STATE_ACTION_DOWNLOADING, 0f, 0L, len, f.getName(), null);
@ -757,7 +777,7 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
if ((len > 0) && (len < 4L * 1024L * 1024L * 1024L)) { if ((len > 0) && (len < 4L * 1024L * 1024L * 1024L)) {
byte[] buffer = new byte[262144]; byte[] buffer = new byte[262144];
InputStream is = response.getEntity().getContent(); InputStream is = urlConnection.getInputStream();
FileOutputStream os = new FileOutputStream(f, false); FileOutputStream os = new FileOutputStream(f, false);
try { try {
int r; int r;
@ -800,31 +820,33 @@ OnWantUpdateCheckListener, OnSharedPreferenceChangeListener {
return false; return false;
} finally { } finally {
updateState(STATE_ACTION_DOWNLOADING, 100f, len, len, null, null); updateState(STATE_ACTION_DOWNLOADING, 100f, len, len, null, null);
if (urlConnection != null) {
urlConnection.disconnect();
}
} }
} }
private long getUrlDownloadSize(String url) { private long getUrlDownloadSize(String url) {
Logger.d("getUrlDownloadSize: %s", url); Logger.d("getUrlDownloadSize: %s", url);
HttpsURLConnection urlConnection = null;
try { try {
HttpParams params = new BasicHttpParams(); urlConnection = setupHttpsRequest(url);
HttpConnectionParams.setConnectionTimeout(params, HTTP_CONNECTION_TIMEOUT); if(urlConnection == null){
HttpConnectionParams.setSoTimeout(params, HTTP_SOCKET_TIMEOUT);
HttpClient client = new DefaultHttpClient(params);
HttpGet request = new HttpGet(url);
HttpResponse response = client.execute(request);
int code = response.getStatusLine().getStatusCode();
if (code != HttpStatus.SC_OK) {
Logger.d("response: %d", code);
return 0; return 0;
} }
return response.getEntity().getContentLength();
return urlConnection.getContentLength();
} catch (Exception e) { } catch (Exception e) {
// Download failed for any number of reasons, timeouts, connection // Download failed for any number of reasons, timeouts, connection
// drops, etc. Just log it in debugging mode. // drops, etc. Just log it in debugging mode.
Logger.ex(e); Logger.ex(e);
}
return 0; return 0;
} finally {
if (urlConnection != null) {
urlConnection.disconnect();
}
}
} }
private String getNewestFullBuild() { private String getNewestFullBuild() {