blob: 00e91c3990cbe9f457f3b08cb67446eeca9cbbba (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
package de.danoeh.antennapod.asynctask;
import java.util.List;
import org.shredzone.flattr4j.exception.FlattrException;
import org.shredzone.flattr4j.model.Flattr;
import android.util.Log;
import android.annotation.SuppressLint;
import android.content.Context;
import android.os.AsyncTask;
import de.danoeh.antennapod.AppConfig;
import de.danoeh.antennapod.util.flattr.FlattrUtils;
import de.danoeh.antennapod.storage.DBWriter;
/** Fetch list of flattred things and flattr status in database in a background thread. */
public class FlattrStatusFetcher extends AsyncTask<Void, Void, Void> {
protected static final String TAG = "FlattrStatusFetcher";
protected Context context;
public FlattrStatusFetcher(Context context) {
super();
this.context = context;
}
@Override
protected Void doInBackground(Void... params) {
if (AppConfig.DEBUG) Log.d(TAG, "Starting background work: Retrieving Flattr status");
Thread.currentThread().setPriority(Thread.MIN_PRIORITY);
try {
List<Flattr> flattredThings = FlattrUtils.retrieveFlattredThings();
DBWriter.setFlattredStatus(context, flattredThings);
}
catch (FlattrException e) {
Log.d(TAG, "flattrQueue exception retrieving list with flattred items " + e.getMessage());
}
if (AppConfig.DEBUG) Log.d(TAG, "Finished background work: Retrieved Flattr status");
return null;
}
@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();
}
}
}
|