From 8ca38b156c1f76aa21671543996f6197f27154ff Mon Sep 17 00:00:00 2001 From: Manuel Martin Date: Tue, 2 Jun 2020 18:57:58 +0200 Subject: [PATCH] Null check cursors and DownloadManager instance (#3454) --- .../vrbrowser/downloads/DownloadsManager.java | 63 ++++++++++++------- 1 file changed, 41 insertions(+), 22 deletions(-) diff --git a/app/src/common/shared/org/mozilla/vrbrowser/downloads/DownloadsManager.java b/app/src/common/shared/org/mozilla/vrbrowser/downloads/DownloadsManager.java index 0203f3206..b31374858 100644 --- a/app/src/common/shared/org/mozilla/vrbrowser/downloads/DownloadsManager.java +++ b/app/src/common/shared/org/mozilla/vrbrowser/downloads/DownloadsManager.java @@ -57,7 +57,8 @@ public void init() { mContext.registerReceiver(mDownloadReceiver, new IntentFilter(DownloadManager.ACTION_DOWNLOAD_COMPLETE)); List downloads = getDownloads(); downloads.forEach(download -> { - if (!new File(UrlUtils.stripProtocol(download.getOutputFile())).exists()) { + if (mDownloadManager != null && + !new File(UrlUtils.stripProtocol(download.getOutputFile())).exists()) { mDownloadManager.remove(download.getId()); } }); @@ -121,8 +122,10 @@ public void startDownload(@NonNull DownloadJob job) { request.setDestinationUri(Uri.parse(outputPath)); } - mDownloadManager.enqueue(request); - scheduleUpdates(); + if (mDownloadManager != null) { + mDownloadManager.enqueue(request); + scheduleUpdates(); + } } @Nullable @@ -144,15 +147,21 @@ public void removeDownload(long downloadId, boolean deleteFiles) { if (file.exists()) { File newFile = new File(UrlUtils.stripProtocol(download.getOutputFile().concat(".bak"))); file.renameTo(newFile); - mDownloadManager.remove(downloadId); + if (mDownloadManager != null) { + mDownloadManager.remove(downloadId); + } newFile.renameTo(file); } else { - mDownloadManager.remove(downloadId); + if (mDownloadManager != null) { + mDownloadManager.remove(downloadId); + } } } else { - mDownloadManager.remove(downloadId); + if (mDownloadManager != null) { + mDownloadManager.remove(downloadId); + } } } notifyDownloadsUpdate(); @@ -166,13 +175,17 @@ public void removeAllDownloads(boolean deleteFiles) { public Download getDownload(long downloadId) { Download download = null; - DownloadManager.Query query = new DownloadManager.Query(); - query.setFilterById(downloadId); - Cursor c = mDownloadManager.query(query); - if (c.moveToFirst()) { - download = Download.from(c); + if (mDownloadManager != null) { + DownloadManager.Query query = new DownloadManager.Query(); + query.setFilterById(downloadId); + Cursor c = mDownloadManager.query(query); + if (c != null) { + if (c.moveToFirst()) { + download = Download.from(c); + } + c.close(); + } } - c.close(); return download; } @@ -180,12 +193,16 @@ public Download getDownload(long downloadId) { public List getDownloads() { List downloads = new ArrayList<>(); - DownloadManager.Query query = new DownloadManager.Query(); - Cursor c = mDownloadManager.query(query); - while (c.moveToNext()) { - downloads.add(Download.from(c)); + if (mDownloadManager != null) { + DownloadManager.Query query = new DownloadManager.Query(); + Cursor c = mDownloadManager.query(query); + if (c != null) { + while (c.moveToNext()) { + downloads.add(Download.from(c)); + } + c.close(); + } } - c.close(); return downloads; } @@ -196,15 +213,17 @@ public void onReceive(Context context, Intent intent) { String action = intent.getAction(); long downloadId = intent.getLongExtra(DownloadManager.EXTRA_DOWNLOAD_ID, 0); - if (DownloadManager.ACTION_DOWNLOAD_COMPLETE.equals(action)) { + if (mDownloadManager != null && DownloadManager.ACTION_DOWNLOAD_COMPLETE.equals(action)) { DownloadManager.Query query = new DownloadManager.Query(); query.setFilterById(downloadId); Cursor c = mDownloadManager.query(query); - if (c.moveToFirst()) { - notifyDownloadsUpdate(); - notifyDownloadCompleted(Download.from(c)); + if (c != null) { + if (c.moveToFirst()) { + notifyDownloadsUpdate(); + notifyDownloadCompleted(Download.from(c)); + } + c.close(); } - c.close(); } } };