Added documentation to DBTasks

This commit is contained in:
daniel oeh 2013-08-10 15:24:49 +02:00
parent fa155f833b
commit 26fad34b65
1 changed files with 122 additions and 15 deletions

View File

@ -11,12 +11,10 @@ import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask; import java.util.concurrent.FutureTask;
import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.locks.ReentrantLock;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.database.Cursor; import android.database.Cursor;
import android.os.Handler;
import android.util.Log; import android.util.Log;
import de.danoeh.antennapod.AppConfig; import de.danoeh.antennapod.AppConfig;
import de.danoeh.antennapod.feed.EventDistributor; import de.danoeh.antennapod.feed.EventDistributor;
@ -32,12 +30,30 @@ import de.danoeh.antennapod.util.NetworkUtils;
import de.danoeh.antennapod.util.QueueAccess; import de.danoeh.antennapod.util.QueueAccess;
import de.danoeh.antennapod.util.exception.MediaFileNotFoundException; import de.danoeh.antennapod.util.exception.MediaFileNotFoundException;
/**
* Provides methods for doing common tasks that use DBReader and DBWriter.
*/
public final class DBTasks { public final class DBTasks {
private static final String TAG = "DBTasks"; private static final String TAG = "DBTasks";
private DBTasks() { private DBTasks() {
} }
/**
* Starts playback of a FeedMedia object's file. This method will build an Intent based on the given parameters to
* start the {@link PlaybackService}.
*
* @param context Used for sending starting Services and Activities.
* @param media The FeedMedia object.
* @param showPlayer If true, starts the appropriate player activity ({@link de.danoeh.antennapod.activity.AudioplayerActivity}
* or {@link de.danoeh.antennapod.activity.VideoplayerActivity}
* @param startWhenPrepared Parameter for the {@link PlaybackService} start intent. If true, playback will start as
* soon as the PlaybackService has finished loading the FeedMedia object's file.
* @param shouldStream Parameter for the {@link PlaybackService} start intent. If true, the FeedMedia object's file
* will be streamed, otherwise the downloaded file will be used. If the downloaded file cannot be
* found, the PlaybackService will shutdown and the database entry of the FeedMedia object will be
* corrected.
*/
public static void playMedia(final Context context, final FeedMedia media, public static void playMedia(final Context context, final FeedMedia media,
boolean showPlayer, boolean startWhenPrepared, boolean shouldStream) { boolean showPlayer, boolean startWhenPrepared, boolean shouldStream) {
try { try {
@ -59,7 +75,7 @@ public final class DBTasks {
true); true);
context.startService(launchIntent); context.startService(launchIntent);
if (showPlayer) { if (showPlayer) {
// Launch Mediaplayer // Launch media player
context.startActivity(PlaybackService.getPlayerActivityIntent( context.startActivity(PlaybackService.getPlayerActivityIntent(
context, media)); context, media));
} }
@ -75,6 +91,14 @@ public final class DBTasks {
} }
private static AtomicBoolean isRefreshing = new AtomicBoolean(false); private static AtomicBoolean isRefreshing = new AtomicBoolean(false);
/**
* Refreshes a given list of Feeds in a separate Thread. This method might ignore subsequent calls if it is still
* enqueuing Feeds for download from a previous call
*
* @param context Might be used for accessing the database
* @param feeds List of Feeds that should be refreshed.
*/
public static void refreshAllFeeds(final Context context, public static void refreshAllFeeds(final Context context,
final List<Feed> feeds) { final List<Feed> feeds) {
if (isRefreshing.compareAndSet(false, true)) { if (isRefreshing.compareAndSet(false, true)) {
@ -95,6 +119,12 @@ public final class DBTasks {
} }
} }
/**
* Refreshes expired Feeds in the list returned by the getExpiredFeedsList(Context, long) method in DBReader.
* The expiration date parameter is determined by the update interval specified in {@link UserPreferences}.
*
* @param context Used for DB access.
*/
public static void refreshExpiredFeeds(final Context context) { public static void refreshExpiredFeeds(final Context context) {
if (AppConfig.DEBUG) if (AppConfig.DEBUG)
Log.d(TAG, "Refreshing expired feeds"); Log.d(TAG, "Refreshing expired feeds");
@ -138,7 +168,10 @@ public final class DBTasks {
} }
/** /**
* Updates a specific feed. * Updates a specific Feed.
*
* @param context Used for requesting the download.
* @param feed The Feed object.
*/ */
public static void refreshFeed(Context context, Feed feed) public static void refreshFeed(Context context, Feed feed)
throws DownloadRequestException { throws DownloadRequestException {
@ -146,10 +179,16 @@ public final class DBTasks {
new Feed(feed.getDownload_url(), new Date(), feed.getTitle())); new Feed(feed.getDownload_url(), new Date(), feed.getTitle()));
} }
/**
* Notifies the database about a missing FeedImage file. This method will attempt to re-download the file.
*
* @param context Used for requesting the download.
* @param image The FeedImage object.
*/
public static void notifyInvalidImageFile(final Context context, public static void notifyInvalidImageFile(final Context context,
final FeedImage image) { final FeedImage image) {
Log.i(TAG, Log.i(TAG,
"The feedmanager was notified about an invalid image download. It will now try to redownload the image file"); "The DB was notified about an invalid image download. It will now try to re-download the image file");
try { try {
DownloadRequester.getInstance().downloadImage(context, image); DownloadRequester.getInstance().downloadImage(context, image);
} catch (DownloadRequestException e) { } catch (DownloadRequestException e) {
@ -158,6 +197,10 @@ public final class DBTasks {
} }
} }
/**
* Notifies the database about a missing FeedMedia file. This method will correct the FeedMedia object's values in the
* DB and send a FeedUpdateBroadcast.
*/
public static void notifyMissingFeedMediaFile(final Context context, public static void notifyMissingFeedMediaFile(final Context context,
final FeedMedia media) { final FeedMedia media) {
Log.i(TAG, Log.i(TAG,
@ -168,6 +211,11 @@ public final class DBTasks {
EventDistributor.getInstance().sendFeedUpdateBroadcast(); EventDistributor.getInstance().sendFeedUpdateBroadcast();
} }
/**
* Request the download of all objects in the queue. from a separate Thread.
*
* @param context Used for requesting the download an accessing the database.
*/
public static void downloadAllItemsInQueue(final Context context) { public static void downloadAllItemsInQueue(final Context context) {
new Thread() { new Thread() {
public void run() { public void run() {
@ -184,6 +232,12 @@ public final class DBTasks {
}.start(); }.start();
} }
/**
* Requests the download of a list of FeedItem objects.
*
* @param context Used for requesting the download and accessing the DB.
* @param items The FeedItem objects.
*/
public static void downloadFeedItems(final Context context, public static void downloadFeedItems(final Context context,
FeedItem... items) throws DownloadRequestException { FeedItem... items) throws DownloadRequestException {
downloadFeedItems(true, context, items); downloadFeedItems(true, context, items);
@ -245,6 +299,14 @@ public final class DBTasks {
return counter; return counter;
} }
/**
* Looks for undownloaded episodes in the queue or list of unread items and request a download if
* 1. Network is available
* 2. There is free space in the episode cache
* This method should NOT be executed on the GUI thread.
*
* @param context Used for accessing the DB.
*/
public static void autodownloadUndownloadedItems(final Context context) { public static void autodownloadUndownloadedItems(final Context context) {
if (AppConfig.DEBUG) if (AppConfig.DEBUG)
Log.d(TAG, "Performing auto-dl of undownloaded episodes"); Log.d(TAG, "Performing auto-dl of undownloaded episodes");
@ -330,6 +392,14 @@ public final class DBTasks {
return 0; return 0;
} }
/**
* Removed downloaded episodes outside of the queue if the episode cache is full. Episodes with a smaller
* 'playbackCompletionDate'-value will be deleted first.
* <p/>
* This method should NOT be executed on the GUI thread.
*
* @param context Used for accessing the DB.
*/
public static void performAutoCleanup(final Context context) { public static void performAutoCleanup(final Context context) {
performAutoCleanup(context, getPerformAutoCleanupArgs(context, 0)); performAutoCleanup(context, getPerformAutoCleanupArgs(context, 0));
} }
@ -383,11 +453,23 @@ public final class DBTasks {
return counter; return counter;
} }
/**
* Adds all FeedItem objects whose 'read'-attribute is false to the queue in a separate thread.
*/
public static void enqueueAllNewItems(final Context context) { public static void enqueueAllNewItems(final Context context) {
long[] unreadItems = DBReader.getUnreadItemIds(context); long[] unreadItems = DBReader.getUnreadItemIds(context);
DBWriter.addQueueItem(context, unreadItems); DBWriter.addQueueItem(context, unreadItems);
} }
/**
* Returns the successor of a FeedItem in the queue.
*
* @param context Used for accessing the DB.
* @param itemId ID of the FeedItem
* @param queue Used for determining the successor of the item. If this parameter is null, the method will load
* the queue from the database in the same thread.
* @return Successor of the FeedItem or null if the FeedItem is not in the queue or has no successor.
*/
public static FeedItem getQueueSuccessorOfItem(Context context, public static FeedItem getQueueSuccessorOfItem(Context context,
final long itemId, List<FeedItem> queue) { final long itemId, List<FeedItem> queue) {
FeedItem result = null; FeedItem result = null;
@ -409,6 +491,13 @@ public final class DBTasks {
return result; return result;
} }
/**
* Loads the queue from the database and checks if the specified FeedItem is in the queue.
* This method should NOT be executed in the GUI thread.
*
* @param context Used for accessing the DB.
* @param feedItemId ID of the FeedItem
*/
public static boolean isInQueue(Context context, final long feedItemId) { public static boolean isInQueue(Context context, final long feedItemId) {
List<Long> queue = DBReader.getQueueIDList(context); List<Long> queue = DBReader.getQueueIDList(context);
return QueueAccess.IDListAccess(queue).contains(feedItemId); return QueueAccess.IDListAccess(queue).contains(feedItemId);
@ -438,6 +527,16 @@ public final class DBTasks {
return null; return null;
} }
/**
* Adds a new Feed to the database or updates the old version if it already exists. If another Feed with the same
* identifying value already exists, this method will add new FeedItems from the new Feed to the existing Feed.
* These FeedItems will be marked as unread.
* This method should NOT be executed on the GUI thread.
*
* @param context Used for accessing the DB.
* @param newFeed The new Feed object.
* @return The updated Feed from the database if it already existed, or the new Feed from the parameters otherwise.
*/
public static synchronized Feed updateFeed(final Context context, public static synchronized Feed updateFeed(final Context context,
final Feed newFeed) { final Feed newFeed) {
// Look up feed in the feedslist // Look up feed in the feedslist
@ -505,11 +604,13 @@ public final class DBTasks {
} }
/** /**
* Searches the titles of FeedItems of a specific feed for a given * Searches the titles of FeedItems of a specific Feed for a given
* string. * string.
* *
* @param context Used for accessing the DB.
* @param feedID The id of the feed whose items should be searched. * @param feedID The id of the feed whose items should be searched.
* @param query The search string * @param query The search string.
* @return A FutureTask object that executes the search request and returns the search result as a List of FeedItems.
*/ */
public static FutureTask<List<FeedItem>> searchFeedItemTitle(final Context context, public static FutureTask<List<FeedItem>> searchFeedItemTitle(final Context context,
final long feedID, final String query) { final long feedID, final String query) {
@ -527,11 +628,13 @@ public final class DBTasks {
} }
/** /**
* Searches the descriptions of FeedItems of a specific feed for a given * Searches the descriptions of FeedItems of a specific Feed for a given
* string. * string.
* *
* @param context Used for accessing the DB.
* @param feedID The id of the feed whose items should be searched. * @param feedID The id of the feed whose items should be searched.
* @param query The search string * @param query The search string
* @return A FutureTask object that executes the search request and returns the search result as a List of FeedItems.
*/ */
public static FutureTask<List<FeedItem>> searchFeedItemDescription(final Context context, public static FutureTask<List<FeedItem>> searchFeedItemDescription(final Context context,
final long feedID, final String query) { final long feedID, final String query) {
@ -549,11 +652,13 @@ public final class DBTasks {
} }
/** /**
* Searches the 'contentEncoded' field of FeedItems of a specific feed for a * Searches the contentEncoded-value of FeedItems of a specific Feed for a given
* given string. * string.
* *
* @param context Used for accessing the DB.
* @param feedID The id of the feed whose items should be searched. * @param feedID The id of the feed whose items should be searched.
* @param query The search string * @param query The search string
* @return A FutureTask object that executes the search request and returns the search result as a List of FeedItems.
*/ */
public static FutureTask<List<FeedItem>> searchFeedItemContentEncoded(final Context context, public static FutureTask<List<FeedItem>> searchFeedItemContentEncoded(final Context context,
final long feedID, final String query) { final long feedID, final String query) {
@ -571,10 +676,12 @@ public final class DBTasks {
} }
/** /**
* Searches chapters for a given string. * Searches chapters of the FeedItems of a specific Feed for a given string.
* *
* @param context Used for accessing the DB.
* @param feedID The id of the feed whose items should be searched. * @param feedID The id of the feed whose items should be searched.
* @param query The search string * @param query The search string
* @return A FutureTask object that executes the search request and returns the search result as a List of FeedItems.
*/ */
public static FutureTask<List<FeedItem>> searchFeedItemChapters(final Context context, public static FutureTask<List<FeedItem>> searchFeedItemChapters(final Context context,
final long feedID, final String query) { final long feedID, final String query) {