diff options
-rw-r--r-- | src/de/danoeh/antennapod/asynctask/FlattrClickWorker.java | 411 |
1 files changed, 195 insertions, 216 deletions
diff --git a/src/de/danoeh/antennapod/asynctask/FlattrClickWorker.java b/src/de/danoeh/antennapod/asynctask/FlattrClickWorker.java index 458b1261b..5c63b2691 100644 --- a/src/de/danoeh/antennapod/asynctask/FlattrClickWorker.java +++ b/src/de/danoeh/antennapod/asynctask/FlattrClickWorker.java @@ -1,22 +1,10 @@ package de.danoeh.antennapod.asynctask; -import java.util.ArrayList; -import java.util.Iterator; -import java.util.List; -import java.util.ListIterator; -import java.util.concurrent.Executor; - -import org.shredzone.flattr4j.exception.FlattrException; -import org.shredzone.flattr4j.model.Flattr; - import android.annotation.SuppressLint; import android.app.Notification; import android.app.NotificationManager; -import android.app.PendingIntent; import android.app.ProgressDialog; import android.content.Context; -import android.content.Intent; -import android.graphics.BitmapFactory; import android.net.ConnectivityManager; import android.net.NetworkInfo; import android.os.AsyncTask; @@ -25,45 +13,47 @@ import android.util.Log; import android.widget.Toast; import de.danoeh.antennapod.AppConfig; import de.danoeh.antennapod.R; -import de.danoeh.antennapod.activity.FeedItemlistActivity; -import de.danoeh.antennapod.feed.Feed; -import de.danoeh.antennapod.feed.FeedItem; -import de.danoeh.antennapod.util.flattr.FlattrThing; -import de.danoeh.antennapod.util.flattr.FlattrUtils; -import de.danoeh.antennapod.util.flattr.FlattrStatus; import de.danoeh.antennapod.storage.DBReader; import de.danoeh.antennapod.storage.DBWriter; +import de.danoeh.antennapod.util.flattr.FlattrThing; +import de.danoeh.antennapod.util.flattr.FlattrUtils; -/** Performs a click action in a background thread. */ +import java.util.ArrayList; +import java.util.List; +import java.util.concurrent.Executor; + +/** + * Performs a click action in a background thread. + */ public class FlattrClickWorker extends AsyncTask<Void, String, Void> { - protected static final String TAG = "FlattrClickWorker"; - protected Context context; - - private final int NOTIFICATION_ID = 4; - - protected String errorMsg; - protected int exitCode; - protected ArrayList<String> flattrd; - protected ArrayList<String> flattr_failed; - - - protected NotificationCompat.Builder notificationCompatBuilder; + protected static final String TAG = "FlattrClickWorker"; + protected Context context; + + private final int NOTIFICATION_ID = 4; + + protected String errorMsg; + protected int exitCode; + protected ArrayList<String> flattrd; + protected ArrayList<String> flattr_failed; + + + protected NotificationCompat.Builder notificationCompatBuilder; private Notification.BigTextStyle notificationBuilder; protected NotificationManager notificationManager; - - protected ProgressDialog progDialog; - protected final static int EXIT_DEFAULT = 0; - protected final static int NO_TOKEN = 1; - protected final static int ENQUEUED = 2; - protected final static int NO_THINGS = 3; + protected ProgressDialog progDialog; + + protected final static int EXIT_DEFAULT = 0; + protected final static int NO_TOKEN = 1; + protected final static int ENQUEUED = 2; + protected final static int NO_THINGS = 3; public final static int ENQUEUE_ONLY = 1; public final static int FLATTR_TOAST = 2; public static final int FLATTR_NOTIFICATION = 3; - private int run_mode = FLATTR_NOTIFICATION; + private int run_mode = FLATTR_NOTIFICATION; private FlattrThing extra_flattr_thing; // additional urls to flattr that do *not* originate from the queue @@ -71,21 +61,21 @@ public class FlattrClickWorker extends AsyncTask<Void, String, Void> { * @param context * @param run_mode can be one of ENQUEUE_ONLY, FLATTR_TOAST and FLATTR_NOTIFICATION */ - public FlattrClickWorker(Context context, int run_mode) { - this(context); - this.run_mode = run_mode; - } - - public FlattrClickWorker(Context context) { - super(); - this.context = context; - exitCode = EXIT_DEFAULT; - - flattrd = new ArrayList<String>(); - flattr_failed = new ArrayList<String>(); - - errorMsg = ""; - } + public FlattrClickWorker(Context context, int run_mode) { + this(context); + this.run_mode = run_mode; + } + + public FlattrClickWorker(Context context) { + super(); + this.context = context; + exitCode = EXIT_DEFAULT; + + flattrd = new ArrayList<String>(); + flattr_failed = new ArrayList<String>(); + + errorMsg = ""; + } /* only used in PreferencesActivity for flattring antennapod itself, * can't really enqueue this thing @@ -98,56 +88,55 @@ public class FlattrClickWorker extends AsyncTask<Void, String, Void> { } protected void onNoAccessToken() { - Log.w(TAG, "No access token was available"); - FlattrUtils.showNoTokenDialog(context, ""); - } - - protected void onFlattrError() { - FlattrUtils.showErrorDialog(context, errorMsg); - } - - protected void onFlattred() { - String notificationTitle = context.getString(R.string.flattrd_label); - String notificationText = "", notificationSubText = "", notificationBigText = ""; - - // text for successfully flattred items - if (flattrd.size() == 1) - notificationText = String.format(context.getString(R.string.flattr_click_success)); - else if (flattrd.size() > 1) // flattred pending items from queue - notificationText = String.format(context.getString(R.string.flattr_click_success_count, flattrd.size())); - - if (flattrd.size() > 0) { - String acc = ""; - for (String s: flattrd) - acc += s + '\n'; - acc = acc.substring(0, acc.length()-2); - - notificationBigText = String.format(context.getString(R.string.flattr_click_success_queue), acc); - } - - // add text for failures - if (flattr_failed.size() > 0) { - notificationTitle = context.getString(R.string.flattrd_failed_label); - notificationText = String.format(context.getString(R.string.flattr_click_failure_count), flattr_failed.size()) - + " " + notificationText; + Log.w(TAG, "No access token was available"); + FlattrUtils.showNoTokenDialog(context, ""); + } + + protected void onFlattrError() { + FlattrUtils.showErrorDialog(context, errorMsg); + } + + protected void onFlattred() { + String notificationTitle = context.getString(R.string.flattrd_label); + String notificationText = "", notificationSubText = "", notificationBigText = ""; + + // text for successfully flattred items + if (flattrd.size() == 1) + notificationText = String.format(context.getString(R.string.flattr_click_success)); + else if (flattrd.size() > 1) // flattred pending items from queue + notificationText = String.format(context.getString(R.string.flattr_click_success_count, flattrd.size())); + + if (flattrd.size() > 0) { + String acc = ""; + for (String s : flattrd) + acc += s + '\n'; + acc = acc.substring(0, acc.length() - 2); + + notificationBigText = String.format(context.getString(R.string.flattr_click_success_queue), acc); + } + + // add text for failures + if (flattr_failed.size() > 0) { + notificationTitle = context.getString(R.string.flattrd_failed_label); + notificationText = String.format(context.getString(R.string.flattr_click_failure_count), flattr_failed.size()) + + " " + notificationText; notificationSubText = flattr_failed.get(0); - String acc = ""; - for (String s: flattr_failed) - acc += s + '\n'; - acc = acc.substring(0, acc.length()-2); - - notificationBigText = String.format(context.getString(R.string.flattr_click_failure), acc) - + "\n" + notificationBigText; - } + String acc = ""; + for (String s : flattr_failed) + acc += s + '\n'; + acc = acc.substring(0, acc.length() - 2); + + notificationBigText = String.format(context.getString(R.string.flattr_click_failure), acc) + + "\n" + notificationBigText; + } Log.d(TAG, "Going to post notification: " + notificationBigText); notificationManager.cancel(NOTIFICATION_ID); - if (run_mode == FLATTR_NOTIFICATION || flattr_failed.size() > 0) - { + if (run_mode == FLATTR_NOTIFICATION || flattr_failed.size() > 0) { if (android.os.Build.VERSION.SDK_INT >= 16) { notificationBuilder = new Notification.BigTextStyle( new Notification.Builder(context) @@ -158,9 +147,7 @@ public class FlattrClickWorker extends AsyncTask<Void, String, Void> { .setSmallIcon(R.drawable.stat_notify_sync)) .bigText(notificationText + "\n" + notificationBigText); notificationManager.notify(NOTIFICATION_ID, notificationBuilder.build()); - } - else - { + } else { notificationCompatBuilder = new NotificationCompat.Builder(context) // need new notificationBuilder and cancel/renotify to get rid of progress bar .setContentTitle(notificationTitle) .setContentText(notificationText) @@ -170,155 +157,147 @@ public class FlattrClickWorker extends AsyncTask<Void, String, Void> { .setOngoing(false); notificationManager.notify(NOTIFICATION_ID, notificationCompatBuilder.build()); } - } - else if (run_mode == FLATTR_TOAST) - { + } else if (run_mode == FLATTR_TOAST) { Toast.makeText(context.getApplicationContext(), notificationText, Toast.LENGTH_LONG) .show(); } - } - - protected void onEnqueue() { - Toast.makeText(context.getApplicationContext(), - R.string.flattr_click_enqueued, - Toast.LENGTH_LONG) - .show(); - } - - protected void onSetupNotification() { + } + + protected void onEnqueue() { + Toast.makeText(context.getApplicationContext(), + R.string.flattr_click_enqueued, + Toast.LENGTH_LONG) + .show(); + } + + protected void onSetupNotification() { if (android.os.Build.VERSION.SDK_INT >= 16) { notificationBuilder = new Notification.BigTextStyle( new Notification.Builder(context) + .setContentTitle(context.getString(R.string.flattring_label)) + .setAutoCancel(true) + .setSmallIcon(R.drawable.stat_notify_sync) + .setProgress(0, 0, true) + .setOngoing(true)); + } else { + notificationCompatBuilder = new NotificationCompat.Builder(context) .setContentTitle(context.getString(R.string.flattring_label)) .setAutoCancel(true) .setSmallIcon(R.drawable.stat_notify_sync) .setProgress(0, 0, true) - .setOngoing(true)); + .setOngoing(true); } - else { - notificationCompatBuilder = new NotificationCompat.Builder(context) - .setContentTitle(context.getString(R.string.flattring_label)) - .setAutoCancel(true) - .setSmallIcon(R.drawable.stat_notify_sync) - .setProgress(0, 0, true) - .setOngoing(true); + + notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); + } + + @Override + protected void onPostExecute(Void result) { + if (AppConfig.DEBUG) Log.d(TAG, "Exit code was " + exitCode); + + switch (exitCode) { + case NO_TOKEN: + notificationManager.cancel(NOTIFICATION_ID); + onNoAccessToken(); + break; + case ENQUEUED: + onEnqueue(); + break; + case EXIT_DEFAULT: + onFlattred(); + break; + case NO_THINGS: // FlattrClickWorker called automatically somewhere to empty flattr queue + notificationManager.cancel(NOTIFICATION_ID); + break; } + } + + @Override + protected void onPreExecute() { + onSetupNotification(); + } + + private static boolean haveInternetAccess(Context context) { + ConnectivityManager cm = + (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); + + NetworkInfo networkInfo = cm.getActiveNetworkInfo(); + return (networkInfo != null && networkInfo.isConnectedOrConnecting()); + } - notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE); - } - - @Override - protected void onPostExecute(Void result) { - if (AppConfig.DEBUG) Log.d(TAG, "Exit code was " + exitCode); - - switch (exitCode) { - case NO_TOKEN: - notificationManager.cancel(NOTIFICATION_ID); - onNoAccessToken(); - break; - case ENQUEUED: - onEnqueue(); - break; - case EXIT_DEFAULT: - onFlattred(); - break; - case NO_THINGS: // FlattrClickWorker called automatically somewhere to empty flattr queue - notificationManager.cancel(NOTIFICATION_ID); - break; - } - } - - @Override - protected void onPreExecute() { - onSetupNotification(); - } - - private static boolean haveInternetAccess(Context context) { - ConnectivityManager cm = - (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); - - NetworkInfo networkInfo = cm.getActiveNetworkInfo(); - return (networkInfo != null && networkInfo.isConnectedOrConnecting()); - } - - @Override - protected Void doInBackground(Void... params) { - if (AppConfig.DEBUG) Log.d(TAG, "Starting background work"); - - exitCode = EXIT_DEFAULT; - - if (!FlattrUtils.hasToken()) { - exitCode = NO_TOKEN; - } - else if (DBReader.getFlattrQueueEmpty(context) && extra_flattr_thing == null) { - exitCode = NO_THINGS; - } - else if (!haveInternetAccess(context) || run_mode == ENQUEUE_ONLY) { - exitCode = ENQUEUED; - } - else { - List<FlattrThing> flattrList = DBReader.getFlattrQueue(context); - Log.d(TAG, "flattrQueue processing list with " + flattrList.size() + " items."); + @Override + protected Void doInBackground(Void... params) { + if (AppConfig.DEBUG) Log.d(TAG, "Starting background work"); + + exitCode = EXIT_DEFAULT; + + if (!FlattrUtils.hasToken()) { + exitCode = NO_TOKEN; + } else if (DBReader.getFlattrQueueEmpty(context) && extra_flattr_thing == null) { + exitCode = NO_THINGS; + } else if (!haveInternetAccess(context) || run_mode == ENQUEUE_ONLY) { + exitCode = ENQUEUED; + } else { + List<FlattrThing> flattrList = DBReader.getFlattrQueue(context); + Log.d(TAG, "flattrQueue processing list with " + flattrList.size() + " items."); if (extra_flattr_thing != null) flattrList.add(extra_flattr_thing); - flattrd.ensureCapacity(flattrList.size()); - - for (FlattrThing thing: flattrList) { - try { - Log.d(TAG, "flattrQueue processing " + thing.getTitle() + " " + thing.getPaymentLink()); - publishProgress(String.format(context.getString(R.string.flattring_thing), thing.getTitle())); - - thing.getFlattrStatus().setUnflattred(); // pop from queue to prevent unflattrable things from getting stuck in flattr queue infinitely - - FlattrUtils.clickUrl(context, thing.getPaymentLink()); - flattrd.add(thing.getTitle()); - - thing.getFlattrStatus().setFlattred(); - } - catch (Exception e) { - Log.d(TAG, "flattrQueue processing exception at item " + thing.getTitle() + " " + e.getMessage()); - flattr_failed.ensureCapacity(flattrList.size()); - flattr_failed.add(thing.getTitle() + ": " + e.getMessage()); - } + flattrd.ensureCapacity(flattrList.size()); + + for (FlattrThing thing : flattrList) { + try { + Log.d(TAG, "flattrQueue processing " + thing.getTitle() + " " + thing.getPaymentLink()); + publishProgress(String.format(context.getString(R.string.flattring_thing), thing.getTitle())); + + thing.getFlattrStatus().setUnflattred(); // pop from queue to prevent unflattrable things from getting stuck in flattr queue infinitely + + FlattrUtils.clickUrl(context, thing.getPaymentLink()); + flattrd.add(thing.getTitle()); + + thing.getFlattrStatus().setFlattred(); + } catch (Exception e) { + Log.d(TAG, "flattrQueue processing exception at item " + thing.getTitle() + " " + e.getMessage()); + flattr_failed.ensureCapacity(flattrList.size()); + flattr_failed.add(thing.getTitle() + ": " + e.getMessage()); + } Log.d(TAG, "flattrQueue processing - going to write thing back to db with flattr_status " + Long.toString(thing.getFlattrStatus().toLong())); DBWriter.setFlattredStatus(context, thing, false); - } - - } - - return null; - } - - @Override - protected void onProgressUpdate(String... names) { + } + + } + + return null; + } + + @Override + protected void onProgressUpdate(String... names) { if (android.os.Build.VERSION.SDK_INT >= 16) { notificationBuilder.setBigContentTitle(names[0]); notificationManager.notify(NOTIFICATION_ID, notificationBuilder.build()); - } - else { + } else { notificationCompatBuilder.setContentText(names[0]); notificationManager.notify(NOTIFICATION_ID, notificationCompatBuilder.build()); } - } - - @SuppressLint("NewApi") - public void executeAsync() { - FlattrUtils.hasToken(); - if (android.os.Build.VERSION.SDK_INT > android.os.Build.VERSION_CODES.GINGERBREAD_MR1) { - executeOnExecutor(THREAD_POOL_EXECUTOR); - } else { - execute(); - } - } + } + + @SuppressLint("NewApi") + public void executeAsync() { + FlattrUtils.hasToken(); + if (android.os.Build.VERSION.SDK_INT > android.os.Build.VERSION_CODES.GINGERBREAD_MR1) { + executeOnExecutor(THREAD_POOL_EXECUTOR); + } else { + execute(); + } + } public void executeSync() { class DirectExecutor implements Executor { public void execute(Runnable r) { - r.run(); + r.run(); } } FlattrUtils.hasToken(); |