mirror of
				https://github.com/TeamNewPipe/NewPipe
				synced 2025-10-26 12:57:39 +00:00 
			
		
		
		
	Merge branch 'dev' into saf-workarround
This commit is contained in:
		| @@ -164,7 +164,7 @@ public class Downloader implements org.schabi.newpipe.extractor.Downloader { | ||||
|         final ResponseBody body = response.body(); | ||||
|  | ||||
|         if (response.code() == 429) { | ||||
|             throw new ReCaptchaException("reCaptcha Challenge requested"); | ||||
|             throw new ReCaptchaException("reCaptcha Challenge requested", siteUrl); | ||||
|         } | ||||
|  | ||||
|         if (body == null) { | ||||
| @@ -214,7 +214,7 @@ public class Downloader implements org.schabi.newpipe.extractor.Downloader { | ||||
|         final ResponseBody body = response.body(); | ||||
|  | ||||
|         if (response.code() == 429) { | ||||
|             throw new ReCaptchaException("reCaptcha Challenge requested"); | ||||
|             throw new ReCaptchaException("reCaptcha Challenge requested", siteUrl); | ||||
|         } | ||||
|  | ||||
|         if (body == null) { | ||||
| @@ -268,7 +268,7 @@ public class Downloader implements org.schabi.newpipe.extractor.Downloader { | ||||
|         final ResponseBody body = response.body(); | ||||
|  | ||||
|         if (response.code() == 429) { | ||||
|             throw new ReCaptchaException("reCaptcha Challenge requested"); | ||||
|             throw new ReCaptchaException("reCaptcha Challenge requested", siteUrl); | ||||
|         } | ||||
|  | ||||
|         if (body == null) { | ||||
|   | ||||
| @@ -37,15 +37,24 @@ import android.webkit.WebViewClient; | ||||
|  */ | ||||
| public class ReCaptchaActivity extends AppCompatActivity { | ||||
|     public static final int RECAPTCHA_REQUEST = 10; | ||||
|     public static final String RECAPTCHA_URL_EXTRA = "recaptcha_url_extra"; | ||||
|  | ||||
|     public static final String TAG = ReCaptchaActivity.class.toString(); | ||||
|     public static final String YT_URL = "https://www.youtube.com"; | ||||
|  | ||||
|     private String url; | ||||
|  | ||||
|     @Override | ||||
|     protected void onCreate(Bundle savedInstanceState) { | ||||
|         super.onCreate(savedInstanceState); | ||||
|         setContentView(R.layout.activity_recaptcha); | ||||
|  | ||||
|         url = getIntent().getStringExtra(RECAPTCHA_URL_EXTRA); | ||||
|         if (url == null || url.isEmpty()) { | ||||
|             url = YT_URL; | ||||
|         } | ||||
|  | ||||
|  | ||||
|         // Set return to Cancel by default | ||||
|         setResult(RESULT_CANCELED); | ||||
|  | ||||
| @@ -73,15 +82,12 @@ public class ReCaptchaActivity extends AppCompatActivity { | ||||
|         myWebView.clearHistory(); | ||||
|         android.webkit.CookieManager cookieManager = CookieManager.getInstance(); | ||||
|         if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { | ||||
|             cookieManager.removeAllCookies(new ValueCallback<Boolean>() { | ||||
|                 @Override | ||||
|                 public void onReceiveValue(Boolean aBoolean) {} | ||||
|             }); | ||||
|             cookieManager.removeAllCookies(aBoolean -> {}); | ||||
|         } else { | ||||
|             cookieManager.removeAllCookie(); | ||||
|         } | ||||
|  | ||||
|         myWebView.loadUrl(YT_URL); | ||||
|         myWebView.loadUrl(url); | ||||
|     } | ||||
|  | ||||
|     private class ReCaptchaWebViewClient extends WebViewClient { | ||||
|   | ||||
| @@ -180,7 +180,7 @@ public abstract class BaseStateFragment<I> extends BaseFragment implements ViewC | ||||
|         } | ||||
|  | ||||
|         if (exception instanceof ReCaptchaException) { | ||||
|             onReCaptchaException(); | ||||
|             onReCaptchaException((ReCaptchaException) exception); | ||||
|             return true; | ||||
|         } else if (exception instanceof IOException) { | ||||
|             showError(getString(R.string.network_error), true); | ||||
| @@ -190,11 +190,13 @@ public abstract class BaseStateFragment<I> extends BaseFragment implements ViewC | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     public void onReCaptchaException() { | ||||
|     public void onReCaptchaException(ReCaptchaException exception) { | ||||
|         if (DEBUG) Log.d(TAG, "onReCaptchaException() called"); | ||||
|         Toast.makeText(activity, R.string.recaptcha_request_toast, Toast.LENGTH_LONG).show(); | ||||
|         // Starting ReCaptcha Challenge Activity | ||||
|         startActivityForResult(new Intent(activity, ReCaptchaActivity.class), ReCaptchaActivity.RECAPTCHA_REQUEST); | ||||
|         Intent intent = new Intent(activity, ReCaptchaActivity.class); | ||||
|         intent.putExtra(ReCaptchaActivity.RECAPTCHA_URL_EXTRA, exception.getUrl()); | ||||
|         startActivityForResult(intent, ReCaptchaActivity.RECAPTCHA_REQUEST); | ||||
|  | ||||
|         showError(getString(R.string.recaptcha_request_toast), false); | ||||
|     } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Christian Schabesberger
					Christian Schabesberger