diff --git a/res/values/strings.xml b/res/values/strings.xml
index a8e8757b..ed26b0df 100644
--- a/res/values/strings.xml
+++ b/res/values/strings.xml
@@ -54,5 +54,5 @@
Enable ads
Showing ads to you supports the project
URL of your tt-rss installation directory, e.g. http://site.com/tt-rss/
-
+ Download and display feed icons
diff --git a/res/xml/preferences.xml b/res/xml/preferences.xml
index 2dedf632..190a706f 100644
--- a/res/xml/preferences.xml
+++ b/res/xml/preferences.xml
@@ -25,6 +25,7 @@
android:entryValues="@array/pref_theme_values" android:summary="@string/pref_theme_long"/>
+
diff --git a/src/org/fox/ttrss/ApiRequest.java b/src/org/fox/ttrss/ApiRequest.java
index a27b3dbb..9af9d33f 100644
--- a/src/org/fox/ttrss/ApiRequest.java
+++ b/src/org/fox/ttrss/ApiRequest.java
@@ -109,7 +109,7 @@ public class ApiRequest extends AsyncTask, Integer, JsonE
InputStream content = execute.getEntity().getContent();
BufferedReader buffer = new BufferedReader(
- new InputStreamReader(content));
+ new InputStreamReader(content), 8192);
String s = "";
String response = "";
diff --git a/src/org/fox/ttrss/FeedsFragment.java b/src/org/fox/ttrss/FeedsFragment.java
index c06b4de1..06d48fbe 100644
--- a/src/org/fox/ttrss/FeedsFragment.java
+++ b/src/org/fox/ttrss/FeedsFragment.java
@@ -1,9 +1,13 @@
package org.fox.ttrss;
import java.io.BufferedInputStream;
+import java.io.BufferedReader;
import java.io.File;
import java.io.FileOutputStream;
+import java.io.InputStream;
+import java.io.InputStreamReader;
import java.lang.reflect.Type;
+import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.Collections;
@@ -11,9 +15,25 @@ import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
+import org.apache.http.HttpHost;
+import org.apache.http.HttpResponse;
+import org.apache.http.auth.AuthScope;
+import org.apache.http.auth.UsernamePasswordCredentials;
+import org.apache.http.client.methods.HttpGet;
+import org.apache.http.client.methods.HttpPost;
+import org.apache.http.conn.scheme.PlainSocketFactory;
+import org.apache.http.conn.scheme.Scheme;
+import org.apache.http.conn.scheme.SchemeRegistry;
+import org.apache.http.entity.StringEntity;
+import org.apache.http.impl.client.DefaultHttpClient;
+import org.apache.http.impl.conn.tsccm.ThreadSafeClientConnManager;
+import org.apache.http.params.BasicHttpParams;
+import org.apache.http.params.HttpParams;
+
import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
+import android.content.SharedPreferences.OnSharedPreferenceChangeListener;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.AsyncTask;
@@ -36,9 +56,10 @@ import com.google.gson.Gson;
import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
+import com.google.gson.JsonParser;
import com.google.gson.reflect.TypeToken;
-public class FeedsFragment extends Fragment implements OnItemClickListener {
+public class FeedsFragment extends Fragment implements OnItemClickListener, OnSharedPreferenceChangeListener {
@SuppressWarnings("unused")
private final String TAG = this.getClass().getSimpleName();
private SharedPreferences m_prefs;
@@ -46,7 +67,7 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
private FeedList m_feeds = new FeedList();
private OnFeedSelectedListener m_feedSelectedListener;
private int m_selectedFeedId;
- private static final String ICON_PATH = "/org.fox.ttrss-icons/";
+ private static final String ICON_PATH = "/org.fox.ttrss/icons/";
private boolean m_enableFeedIcons;
public interface OnFeedSelectedListener {
@@ -93,7 +114,7 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
list.setAdapter(m_adapter);
list.setOnItemClickListener(this);
- m_enableFeedIcons = m_prefs.getBoolean("enable_feed_icons", false);
+ m_enableFeedIcons = m_prefs.getBoolean("download_feed_icons", false);
if (m_feeds == null || m_feeds.size() == 0)
refresh(false);
@@ -113,6 +134,8 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
super.onAttach(activity);
m_prefs = PreferenceManager.getDefaultSharedPreferences(getActivity().getApplicationContext());
+ m_prefs.registerOnSharedPreferenceChangeListener(this);
+
m_feedSelectedListener = (OnFeedSelectedListener) activity;
}
@@ -404,36 +427,17 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
try {
File storage = Environment.getExternalStorageDirectory();
final File iconPath = new File(storage.getAbsolutePath() + ICON_PATH);
- if (!iconPath.exists()) iconPath.mkdir();
+ if (!iconPath.exists()) iconPath.mkdirs();
- final FeedList feeds = params[0];
-
if (iconPath.exists()) {
- for (Feed feed : feeds) {
+ for (Feed feed : params[0]) {
if (feed.id > 0 && feed.has_icon) {
- File iconFile = new File(iconPath.getAbsolutePath() + "/" + feed.id + ".ico");
+ File outputFile = new File(iconPath.getAbsolutePath() + "/" + feed.id + ".ico");
String fetchUrl = m_baseUrl + "/" + feed.id + ".ico";
- if (!iconFile.exists()) {
- //Log.d(TAG, "Downloading " + fetchUrl);
-
- try {
- BufferedInputStream is = new BufferedInputStream(new URL(fetchUrl).openStream(), 1024);
- FileOutputStream fos = new FileOutputStream(iconFile);
-
- byte[] buffer = new byte[1024];
- int len = 0;
- while ((len = is.read(buffer)) != -1) {
- fos.write(buffer, 0, len);
- }
-
- fos.close();
- is.close();
- } catch (Exception e) {
- Log.d(TAG, "Error downloading " + fetchUrl);
- e.printStackTrace();
- }
-
+ if (!outputFile.exists()) {
+ downloadFile(fetchUrl, outputFile.getAbsolutePath());
+ Thread.sleep(2000);
}
}
}
@@ -445,9 +449,79 @@ public class FeedsFragment extends Fragment implements OnItemClickListener {
return null;
}
+ protected void downloadFile(String fetchUrl, String outputFile) {
+ DefaultHttpClient client;
+
+ if (m_prefs.getBoolean("ssl_trust_any", false)) {
+ SchemeRegistry schemeRegistry = new SchemeRegistry();
+ schemeRegistry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
+ schemeRegistry.register(new Scheme("https", new EasySSLSocketFactory(), 443));
+
+ HttpParams httpParams = new BasicHttpParams();
+
+ client = new DefaultHttpClient(new ThreadSafeClientConnManager(httpParams, schemeRegistry), httpParams);
+ } else {
+ client = new DefaultHttpClient();
+ }
+
+ HttpGet httpGet = new HttpGet(fetchUrl);
+
+ String httpLogin = m_prefs.getString("http_login", "");
+ String httpPassword = m_prefs.getString("http_password", "");
+
+ if (httpLogin.length() > 0) {
+
+ URL targetUrl;
+ try {
+ targetUrl = new URL(fetchUrl);
+ } catch (MalformedURLException e) {
+ e.printStackTrace();
+ return;
+ }
+
+ HttpHost targetHost = new HttpHost(targetUrl.getHost(), targetUrl.getPort(), targetUrl.getProtocol());
+
+ client.getCredentialsProvider().setCredentials(
+ new AuthScope(targetHost.getHostName(), targetHost.getPort()),
+ new UsernamePasswordCredentials(httpLogin, httpPassword));
+ }
+
+
+ try {
+ HttpResponse execute = client.execute(httpGet);
+
+ InputStream content = execute.getEntity().getContent();
+
+ BufferedInputStream is = new BufferedInputStream(content, 1024);
+ FileOutputStream fos = new FileOutputStream(outputFile);
+
+ byte[] buffer = new byte[1024];
+ int len = 0;
+ while ((len = is.read(buffer)) != -1) {
+ fos.write(buffer, 0, len);
+ }
+
+ fos.close();
+ is.close();
+
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+
+ }
+
protected void onPostExecute(Integer result) {
m_adapter.notifyDataSetInvalidated();
}
}
+
+ @Override
+ public void onSharedPreferenceChanged(SharedPreferences sharedPreferences,
+ String key) {
+
+ sortFeeds();
+ m_enableFeedIcons = m_prefs.getBoolean("download_feed_icons", false);
+
+ }
}
diff --git a/src/org/fox/ttrss/MainActivity.java b/src/org/fox/ttrss/MainActivity.java
index 10beb477..763e1fa7 100644
--- a/src/org/fox/ttrss/MainActivity.java
+++ b/src/org/fox/ttrss/MainActivity.java
@@ -262,12 +262,6 @@ public class MainActivity extends FragmentActivity implements FeedsFragment.OnFe
Intent refresh = new Intent(this, MainActivity.class);
startActivity(refresh);
finish();
- } else {
- FeedsFragment frag = (FeedsFragment)getSupportFragmentManager().findFragmentById(R.id.feeds_fragment);
-
- if (frag != null) {
- frag.sortFeeds();
- }
}
}