Merge branch 'master' of github.com:theScrabi/NewPipe

This commit is contained in:
Adam Howard 2016-01-04 01:15:33 +00:00
commit fc44d9e36e
12 changed files with 118 additions and 41 deletions

View file

@ -36,6 +36,7 @@ NewPipe does not use any Google framework libraries, or the YouTube API. It only
* Open a video in Kodi * Open a video in Kodi
* Show Next/Related videos * Show Next/Related videos
* Search YouTube in a specific language * Search YouTube in a specific language
* Orbot/Tor support (no streaming yet)
### Coming Features ### Coming Features

View file

@ -8,8 +8,8 @@ android {
applicationId "org.schabi.newpipe" applicationId "org.schabi.newpipe"
minSdkVersion 15 minSdkVersion 15
targetSdkVersion 23 targetSdkVersion 23
versionCode 10 versionCode 11
versionName "0.7.1" versionName "0.7.2"
} }
buildTypes { buildTypes {
release { release {

View file

@ -15,10 +15,13 @@ public class App extends Application {
@Override @Override
public void onCreate() { public void onCreate() {
super.onCreate(); super.onCreate();
// if Orbot is installed, then default to using Tor, the user can still override
if (OrbotHelper.requestStartTor(this)) {
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this); SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
configureTor(prefs.getBoolean(getString(R.string.useTor), true)); if(prefs.getBoolean(getString(R.string.useTorKey), false)) {
OrbotHelper.requestStartTor(this);
configureTor(true);
} else {
configureTor(false);
} }
} }

View file

@ -1,23 +1,23 @@
package org.schabi.newpipe; package org.schabi.newpipe;
import android.app.Notification;
import android.app.NotificationManager; import android.app.NotificationManager;
import android.content.Context; import android.content.Context;
import android.content.SharedPreferences;
import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable;
import android.os.AsyncTask; import android.os.AsyncTask;
import android.preference.PreferenceManager;
import android.support.v4.app.NotificationCompat; import android.support.v4.app.NotificationCompat;
import android.util.Log; import android.util.Log;
import java.io.BufferedInputStream; import java.io.BufferedInputStream;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.File;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.net.HttpURLConnection; import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL; import java.net.URL;
import java.net.UnknownHostException; import java.net.UnknownHostException;
@ -47,7 +47,6 @@ import info.guardianproject.netcipher.NetCipher;
public class Downloader { public class Downloader {
public static final String TAG = "Downloader"; public static final String TAG = "Downloader";
private static final String USER_AGENT = "Mozilla/5.0"; private static final String USER_AGENT = "Mozilla/5.0";
/**Download the text file at the supplied URL as in download(String), /**Download the text file at the supplied URL as in download(String),
@ -59,7 +58,7 @@ public class Downloader {
String ret = ""; String ret = "";
try { try {
URL url = new URL(siteUrl); URL url = new URL(siteUrl);
HttpsURLConnection con = NetCipher.getHttpsURLConnection(url); HttpsURLConnection con = (HttpsURLConnection) url.openConnection();
con.setRequestProperty("Accept-Language", language); con.setRequestProperty("Accept-Language", language);
ret = dl(con); ret = dl(con);
} }
@ -68,8 +67,9 @@ public class Downloader {
} }
return ret; return ret;
} }
/**Common functionality between download(String url) and download(String url, String language)*/ /**Common functionality between download(String url) and download(String url, String language)*/
private static String dl(HttpURLConnection con) throws IOException { private static String dl(HttpsURLConnection con) throws IOException {
StringBuilder response = new StringBuilder(); StringBuilder response = new StringBuilder();
try { try {

View file

@ -1,6 +1,5 @@
package org.schabi.newpipe; package org.schabi.newpipe;
import android.annotation.SuppressLint;
import android.content.Context; import android.content.Context;
import android.content.SharedPreferences; import android.content.SharedPreferences;
import android.content.res.Resources; import android.content.res.Resources;
@ -22,7 +21,8 @@ public class Localization {
public static Locale getPreferredLocale(Context context) { public static Locale getPreferredLocale(Context context) {
SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(context); SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(context);
String languageCode = sp.getString(String.valueOf(R.string.searchLanguage), "en"); String languageCode = sp.getString(String.valueOf(R.string.searchLanguagePreference),
context.getString(R.string.defaultLanguageItem));
if(languageCode.length() == 2) { if(languageCode.length() == 2) {
return new Locale(languageCode); return new Locale(languageCode);

View file

@ -1,14 +1,19 @@
package org.schabi.newpipe; package org.schabi.newpipe;
import android.app.Activity; import android.app.Activity;
import android.app.SharedElementCallback;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.SharedPreferences;
import android.content.res.Configuration; import android.content.res.Configuration;
import android.os.Bundle; import android.os.Bundle;
import android.preference.CheckBoxPreference; import android.preference.CheckBoxPreference;
import android.preference.EditTextPreference;
import android.preference.ListPreference;
import android.preference.Preference; import android.preference.Preference;
import android.preference.PreferenceActivity; import android.preference.PreferenceActivity;
import android.preference.PreferenceFragment; import android.preference.PreferenceFragment;
import android.preference.PreferenceManager;
import android.support.annotation.LayoutRes; import android.support.annotation.LayoutRes;
import android.support.annotation.NonNull; import android.support.annotation.NonNull;
import android.support.v7.app.ActionBar; import android.support.v7.app.ActionBar;
@ -59,37 +64,90 @@ public class SettingsActivity extends PreferenceActivity {
} }
public static class SettingsFragment extends PreferenceFragment { public static class SettingsFragment extends PreferenceFragment{
SharedPreferences.OnSharedPreferenceChangeListener prefListener;
// get keys
String DEFAULT_RESOLUTION_PREFERENCE;
String DEFAULT_AUDIO_FORMAT_PREFERENCE;
String SEARCH_LANGUAGE_PREFERENCE;
String DOWNLOAD_PATH_PREFERENCE;
String USE_TOR_KEY;
private ListPreference defaultResolutionPreference;
private ListPreference defaultAudioFormatPreference;
private ListPreference searchLanguagePreference;
private EditTextPreference downloadPathPreference;
private CheckBoxPreference useTorCheckBox; private CheckBoxPreference useTorCheckBox;
private SharedPreferences defaultPreferences;
@Override @Override
public void onCreate(Bundle savedInstanceState) { public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.settings_screen); addPreferencesFromResource(R.xml.settings_screen);
// if Orbot is installed, then default to using Tor, the user can still override
useTorCheckBox = (CheckBoxPreference) findPreference(getString(R.string.useTor));
final Activity activity = getActivity(); final Activity activity = getActivity();
final boolean useTor = OrbotHelper.isOrbotInstalled(activity);
useTorCheckBox.setDefaultValue(useTor); defaultPreferences = PreferenceManager.getDefaultSharedPreferences(activity);
useTorCheckBox.setChecked(useTor);
useTorCheckBox.setOnPreferenceChangeListener(new Preference.OnPreferenceChangeListener() { // get keys
DEFAULT_RESOLUTION_PREFERENCE =getString(R.string.defaultResolutionPreference);
DEFAULT_AUDIO_FORMAT_PREFERENCE =getString(R.string.defaultAudioFormatPreference);
SEARCH_LANGUAGE_PREFERENCE =getString(R.string.searchLanguagePreference);
DOWNLOAD_PATH_PREFERENCE = getString(R.string.downloadPathPreference);
USE_TOR_KEY = getString(R.string.useTorKey);
// get pref objects
defaultResolutionPreference =
(ListPreference) findPreference(DEFAULT_RESOLUTION_PREFERENCE);
defaultAudioFormatPreference =
(ListPreference) findPreference(DEFAULT_AUDIO_FORMAT_PREFERENCE);
searchLanguagePreference =
(ListPreference) findPreference(SEARCH_LANGUAGE_PREFERENCE);
downloadPathPreference =
(EditTextPreference) findPreference(DOWNLOAD_PATH_PREFERENCE);
useTorCheckBox = (CheckBoxPreference) findPreference(USE_TOR_KEY);
prefListener = new SharedPreferences.OnSharedPreferenceChangeListener() {
@Override @Override
public boolean onPreferenceChange(Preference preference, Object o) { public void onSharedPreferenceChanged(SharedPreferences sharedPreferences,
boolean useTor = (Boolean) o; String key) {
if (useTor) { Activity a = getActivity();
if (OrbotHelper.isOrbotInstalled(activity)) { updateSummary();
if (defaultPreferences.getBoolean(USE_TOR_KEY, false)) {
if (OrbotHelper.isOrbotInstalled(a)) {
App.configureTor(true); App.configureTor(true);
OrbotHelper.requestStartTor(a);
} else { } else {
Intent intent = OrbotHelper.getOrbotInstallIntent(activity); Intent intent = OrbotHelper.getOrbotInstallIntent(a);
activity.startActivityForResult(intent, REQUEST_INSTALL_ORBOT); a.startActivityForResult(intent, REQUEST_INSTALL_ORBOT);
} }
} else { } else {
App.configureTor(false); App.configureTor(false);
} }
return true;
} }
}); };
defaultPreferences.registerOnSharedPreferenceChangeListener(prefListener);
updateSummary();
}
// This is used to show the status of some preference in the description
private void updateSummary() {
defaultResolutionPreference.setSummary(
defaultPreferences.getString(DEFAULT_RESOLUTION_PREFERENCE,
getString(R.string.defaultResolutionListItem)));
defaultAudioFormatPreference.setSummary(
defaultPreferences.getString(DEFAULT_AUDIO_FORMAT_PREFERENCE,
getString(R.string.defaultAudioFormat)));
searchLanguagePreference.setSummary(
defaultPreferences.getString(SEARCH_LANGUAGE_PREFERENCE,
getString(R.string.defaultLanguageItem)));
downloadPathPreference.setSummary(
defaultPreferences.getString(DOWNLOAD_PATH_PREFERENCE,
getString(R.string.downloadLocationSummary)));
} }
} }

View file

@ -99,8 +99,9 @@ public class VideoItemListFragment extends ListFragment {
public void run() { public void run() {
try { try {
SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(getContext()); SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(getContext());
String searchLanguageKey = getContext().getString(R.string.searchLanguage); String searchLanguageKey = getContext().getString(R.string.searchLanguagePreference);
String searchLanguage = sp.getString(searchLanguageKey, "en"); String searchLanguage = sp.getString(searchLanguageKey,
getString(R.string.defaultLanguageItem));
SearchEngine.Result result = engine.search(query, page, searchLanguage); SearchEngine.Result result = engine.search(query, page, searchLanguage);
Log.i(TAG, "language code passed:\""+searchLanguage+"\""); Log.i(TAG, "language code passed:\""+searchLanguage+"\"");
if(run) { if(run) {

View file

@ -107,6 +107,7 @@ public abstract class VideoExtractor {
} }
//todo: add licence field
protected abstract int getErrorCode(); protected abstract int getErrorCode();
protected abstract String getErrorMessage(); protected abstract String getErrorMessage();
protected abstract String getVideoUrl(String videoId); protected abstract String getVideoUrl(String videoId);

View file

@ -44,10 +44,18 @@
<string name="settingsCategoryVideoAudioTitle">VIDEO &amp; AUDIO</string> <string name="settingsCategoryVideoAudioTitle">VIDEO &amp; AUDIO</string>
<string name="settingsCategoryVideoInfoTittle">INFO</string> <string name="settingsCategoryVideoInfoTittle">INFO</string>
<string name="settingsCategoryEtcTitle">ETC</string> <string name="settingsCategoryEtcTitle">ETC</string>
<string name="searchLanguageTitle">Bevorzugte Sprache</string> <string name="searchLanguageTitle">Bevorzugte Sprache des Inhalts</string>
<string name="itemThumbnailViewDescription">Video-Vorschau-Bild</string> <string name="itemThumbnailViewDescription">Video-Vorschau-Bild</string>
<string name="detailThumbnailViewDescription">Video-Vorschau-Bild</string> <string name="detailThumbnailViewDescription">Video-Vorschau-Bild</string>
<string name="detailUploaderThumbnailViewDescription">Nutzerbild</string> <string name="detailUploaderThumbnailViewDescription">Nutzerbild</string>
<string name="detailThumbsDownImgViewDescription">gefällt nicht</string> <string name="detailThumbsDownImgViewDescription">Gefällt nicht</string>
<string name="detailThumbsUpImgViewDescription">gefällt</string> <string name="detailThumbsUpImgViewDescription">Gefällt</string>
<string name="loading">Lade</string>
<string name="useExternalVideoPlayerTitle">Benutze externen Videoabspieler</string>
<string name="useExternalAudioPlayerTitle">Benutze externen Audioabspieler</string>
<string name="backgroundPlayerStartPlayingToast">Spiele im Hintergrund ab</string>
<string name="play">Abspielen</string>
<string name="useTor">Benutze TOR</string>
<string name="useTorSummary">Erzwinge das Herunterladen durch TOR für verbesserte Privatsphäre (Videostream noch nicht unterstützt)</string>
</resources> </resources>

View file

@ -54,4 +54,6 @@
<string name="loading">Chargement</string> <string name="loading">Chargement</string>
<string name="play">Lecture</string> <string name="play">Lecture</string>
</resources> <string name="useTor">Utiliser Tor</string>
<string name="useTorSummary">Forcer le trafic de téléchargement via Tor pour plus de confidentialité (vidéos streaming non supporté)</string>
</resources>

View file

@ -29,7 +29,8 @@
</string-array> </string-array>
<string name="defaultAudioFormat">m4a</string> <string name="defaultAudioFormat">m4a</string>
<string name="showNextVideo">show_next_video</string> <string name="showNextVideo">show_next_video</string>
<string name="searchLanguage">search_language</string> <string name="searchLanguagePreference">search_language</string>
<string name="useTorKey">use_tor</string>
<!-- TODO: scrape these programmatically, then store in a local cache --> <!-- TODO: scrape these programmatically, then store in a local cache -->
<!-- alternatively, load these from some local android data store --> <!-- alternatively, load these from some local android data store -->
<string-array name='languageCodes'> <string-array name='languageCodes'>
@ -111,6 +112,7 @@
<item>ja</item> <item>ja</item>
<item>ko</item> <item>ko</item>
</string-array> </string-array>
<string name="defaultLanguageItem">en</string>
<string-array name='languageNames'> <string-array name='languageNames'>
<item>Afrikaans</item> <item>Afrikaans</item>
<item>Azərbaycan</item> <item>Azərbaycan</item>

View file

@ -43,11 +43,11 @@
android:defaultValue="false" /> android:defaultValue="false" />
<ListPreference <ListPreference
android:key="@string/searchLanguage" android:key="@string/searchLanguagePreference"
android:title="@string/searchLanguageTitle" android:title="@string/searchLanguageTitle"
android:entries="@array/languageNames" android:entries="@array/languageNames"
android:entryValues="@array/languageCodes" android:entryValues="@array/languageCodes"
android:defaultValue="en" /> android:defaultValue="@string/defaultLanguageItem" />
<CheckBoxPreference <CheckBoxPreference
android:key="@string/showNextVideo" android:key="@string/showNextVideo"
@ -73,9 +73,10 @@
android:defaultValue="false" /> android:defaultValue="false" />
<CheckBoxPreference <CheckBoxPreference
android:key="@string/useTor" android:key="@string/useTorKey"
android:title="@string/useTor" android:title="@string/useTor"
android:summary="@string/useTorSummary" /> android:summary="@string/useTorSummary"
android:defaultValue="false"/>
</PreferenceCategory> </PreferenceCategory>
</PreferenceScreen> </PreferenceScreen>