[YouTube] Expand regex to match n param decrypt function
Temporary solution
This commit is contained in:
		
							parent
							
								
									6335823843
								
							
						
					
					
						commit
						1c78976900
					
				
					 2 changed files with 19 additions and 1 deletions
				
			
		|  | @ -70,7 +70,7 @@ public class YoutubeThrottlingDecrypter { | ||||||
|     @Nonnull |     @Nonnull | ||||||
|     private String parseDecodeFunction(final String playerJsCode, final String functionName) |     private String parseDecodeFunction(final String playerJsCode, final String functionName) | ||||||
|             throws Parser.RegexException { |             throws Parser.RegexException { | ||||||
|         Pattern functionPattern = Pattern.compile(functionName + "=function(.*?;)\n", |         Pattern functionPattern = Pattern.compile(functionName + "=function(.*?};)\n", | ||||||
|                 Pattern.DOTALL); |                 Pattern.DOTALL); | ||||||
|         return "function " + functionName + Parser.matchGroup1(functionPattern, playerJsCode); |         return "function " + functionName + Parser.matchGroup1(functionPattern, playerJsCode); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -2,6 +2,7 @@ package org.schabi.newpipe.extractor.services.youtube; | ||||||
| 
 | 
 | ||||||
| import org.junit.Before; | import org.junit.Before; | ||||||
| import org.junit.Test; | import org.junit.Test; | ||||||
|  | import org.mozilla.javascript.EvaluatorException; | ||||||
| import org.schabi.newpipe.downloader.DownloaderTestImpl; | import org.schabi.newpipe.downloader.DownloaderTestImpl; | ||||||
| import org.schabi.newpipe.extractor.NewPipe; | import org.schabi.newpipe.extractor.NewPipe; | ||||||
| import org.schabi.newpipe.extractor.exceptions.ParsingException; | import org.schabi.newpipe.extractor.exceptions.ParsingException; | ||||||
|  | @ -11,6 +12,7 @@ import java.io.IOException; | ||||||
| import static org.hamcrest.CoreMatchers.equalTo; | import static org.hamcrest.CoreMatchers.equalTo; | ||||||
| import static org.hamcrest.MatcherAssert.assertThat; | import static org.hamcrest.MatcherAssert.assertThat; | ||||||
| import static org.junit.Assert.assertNotEquals; | import static org.junit.Assert.assertNotEquals; | ||||||
|  | import static org.junit.Assert.fail; | ||||||
| 
 | 
 | ||||||
| public class YoutubeThrottlingDecrypterTest { | public class YoutubeThrottlingDecrypterTest { | ||||||
| 
 | 
 | ||||||
|  | @ -19,6 +21,22 @@ public class YoutubeThrottlingDecrypterTest { | ||||||
|         NewPipe.init(DownloaderTestImpl.getInstance()); |         NewPipe.init(DownloaderTestImpl.getInstance()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Test | ||||||
|  |     public void testExtractFunction__success() throws ParsingException { | ||||||
|  |         String[] videoIds = {"jE1USQrs1rw", "CqxjzfudGAc", "goH-9MfQI7w", "KYIdr_7H5Yw", "J1WeqmGbYeI"}; | ||||||
|  | 
 | ||||||
|  |         final String encryptedUrl = "https://r6---sn-4g5ednek.googlevideo.com/videoplayback?expire=1626562120&ei=6AnzYO_YBpql1gLGkb_IBQ&ip=127.0.0.1&id=o-ANhBEf36Z5h-8U9DDddtPDqtS0ZNwf0XJAAigudKI2uI&itag=278&aitags=133%2C134%2C135%2C136%2C137%2C160%2C242%2C243%2C244%2C247%2C248%2C278&source=youtube&requiressl=yes&vprv=1&mime=video%2Fwebm&ns=TvecOReN0vPuXb3j_zq157IG&gir=yes&clen=2915100&dur=270.203&lmt=1608157174907785&keepalive=yes&fexp=24001373,24007246&c=WEB&txp=5535432&n=N9BWSTFT7vvBJrvQ&sparams=expire%2Cei%2Cip%2Cid%2Caitags%2Csource%2Crequiressl%2Cvprv%2Cmime%2Cns%2Cgir%2Cclen%2Cdur%2Clmt&alr=yes&sig=AOq0QJ8wRQIgW6XnUDKPDSxiT0_KE_tDDMpcaCJl2Un5p0Fu9qZNQGkCIQDWxsDHi_s2BEmRqIbd1C5g_gzfihB7RZLsScKWNMwzzA%3D%3D&cpn=9r2yt3BqcYmeb2Yu&cver=2.20210716.00.00&redirect_counter=1&cm2rm=sn-4g5ezy7s&cms_redirect=yes&mh=Y5&mm=34&mn=sn-4g5ednek&ms=ltu&mt=1626540524&mv=m&mvi=6&pl=43&lsparams=mh,mm,mn,ms,mv,mvi,pl&lsig=AG3C_xAwRQIhAIUzxTn9Vw1-vm-_7OQ5-0h1M6AZsY9Bx1FlCCTeMICzAiADtGggbn4Znsrh2EnvyOsGnYdRGcbxn4mW9JMOQiInDQ%3D%3D&range=259165-480735&rn=11&rbuf=20190"; | ||||||
|  | 
 | ||||||
|  |         for (String videoId : videoIds) { | ||||||
|  |             try { | ||||||
|  |                 final String decryptedUrl = new YoutubeThrottlingDecrypter(videoId).apply(encryptedUrl); | ||||||
|  |                 assertNotEquals(encryptedUrl, decryptedUrl); | ||||||
|  |             } catch (EvaluatorException e) { | ||||||
|  |                 fail("Failed to extract n param decrypt function for video " + videoId + "\n" + e); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Test |     @Test | ||||||
|     public void testDecode__success() throws ParsingException { |     public void testDecode__success() throws ParsingException { | ||||||
|         // URL extracted from browser with the dev tools |         // URL extracted from browser with the dev tools | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue