mirror of
				https://github.com/iv-org/invidious.git
				synced 2025-10-22 16:58:28 -05:00 
			
		
		
		
	Merge pull request #1922 from Svallinn/search_api_fixes
Fix channels' search API
This commit is contained in:
		
						commit
						c4c2e01213
					
				| @ -27,11 +27,11 @@ describe "Helper" do | |||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   describe "#produce_channel_search_url" do |   describe "#produce_channel_search_continuation" do | ||||||
|     it "correctly produces token for searching a specific channel" do |     it "correctly produces token for searching a specific channel" do | ||||||
|       produce_channel_search_url("UCXuqSBlHAE6Xw-yeJA0Tunw", "", 100).should eq("/browse_ajax?continuation=4qmFsgI2EhhVQ1h1cVNCbEhBRTZYdy15ZUpBMFR1bncaGEVnWnpaV0Z5WTJnNEFYb0RNVEF3dUFFQVoA&gl=US&hl=en") |       produce_channel_search_continuation("UCXuqSBlHAE6Xw-yeJA0Tunw", "", 100).should eq("4qmFsgJqEhhVQ1h1cVNCbEhBRTZYdy15ZUpBMFR1bncaIEVnWnpaV0Z5WTJnd0FUZ0JZQUY2QkVkS2IxaTRBUUE9WgCaAilicm93c2UtZmVlZFVDWHVxU0JsSEFFNlh3LXllSkEwVHVud3NlYXJjaA%3D%3D") | ||||||
| 
 | 
 | ||||||
|       produce_channel_search_url("UCXuqSBlHAE6Xw-yeJA0Tunw", "По ожиशुपतिरपि子而時ஸ்றீனி", 0).should eq("/browse_ajax?continuation=4qmFsgJ0EhhVQ1h1cVNCbEhBRTZYdy15ZUpBMFR1bncaGEVnWnpaV0Z5WTJnNEFYb0JNTGdCQUE9PVo-0J_QviDQvtC20LjgpLbgpYHgpKrgpKTgpL_gpLDgpKrgpL_lrZDogIzmmYLgrrjgr43grrHgr4Dgrqngrr8%3D&gl=US&hl=en") |       produce_channel_search_continuation("UCXuqSBlHAE6Xw-yeJA0Tunw", "По ожиशुपतिरपि子而時ஸ்றீனி", 0).should eq("4qmFsgKoARIYVUNYdXFTQmxIQUU2WHcteWVKQTBUdW53GiBFZ1p6WldGeVkyZ3dBVGdCWUFGNkJFZEJRVDI0QVFBPVo-0J_QviDQvtC20LjgpLbgpYHgpKrgpKTgpL_gpLDgpKrgpL_lrZDogIzmmYLgrrjgr43grrHgr4Dgrqngrr-aAilicm93c2UtZmVlZFVDWHVxU0JsSEFFNlh3LXllSkEwVHVud3NlYXJjaA%3D%3D") | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -231,20 +231,32 @@ end | |||||||
| alias SearchItem = SearchVideo | SearchChannel | SearchPlaylist | alias SearchItem = SearchVideo | SearchChannel | SearchPlaylist | ||||||
| 
 | 
 | ||||||
| def channel_search(query, page, channel) | def channel_search(query, page, channel) | ||||||
|   response = YT_POOL.client &.get("/channel/#{channel}?hl=en&gl=US") |   response = YT_POOL.client &.get("/channel/#{channel}") | ||||||
|   response = YT_POOL.client &.get("/user/#{channel}?hl=en&gl=US") if response.headers["location"]? |  | ||||||
|   response = YT_POOL.client &.get("/c/#{channel}?hl=en&gl=US") if response.headers["location"]? |  | ||||||
| 
 | 
 | ||||||
|   ucid = response.body.match(/\\"channelId\\":\\"(?<ucid>[^\\]+)\\"/).try &.["ucid"]? |   if response.status_code == 404 | ||||||
|  |     response = YT_POOL.client &.get("/user/#{channel}") | ||||||
|  |     response = YT_POOL.client &.get("/c/#{channel}") if response.status_code == 404 | ||||||
|  |     initial_data = extract_initial_data(response.body) | ||||||
|  |     ucid = initial_data["header"]["c4TabbedHeaderRenderer"]?.try &.["channelId"].as_s? | ||||||
|  |     raise InfoException.new("Impossible to extract channel ID from page") if !ucid | ||||||
|  |   else | ||||||
|  |     ucid = channel | ||||||
|  |   end | ||||||
| 
 | 
 | ||||||
|   return 0, [] of SearchItem if !ucid |   continuation = produce_channel_search_continuation(ucid, query, page) | ||||||
|  |   response_json = request_youtube_api_browse(continuation) | ||||||
| 
 | 
 | ||||||
|   url = produce_channel_search_url(ucid, query, page) |   result = JSON.parse(response_json) | ||||||
|   response = YT_POOL.client &.get(url) |   continuationItems = result["onResponseReceivedActions"]? | ||||||
|   initial_data = JSON.parse(response.body).as_a.find &.["response"]? |     .try &.[0]["appendContinuationItemsAction"]["continuationItems"] | ||||||
|   return 0, [] of SearchItem if !initial_data | 
 | ||||||
|   author = initial_data["response"]?.try &.["metadata"]?.try &.["channelMetadataRenderer"]?.try &.["title"]?.try &.as_s |   return 0, [] of SearchItem if !continuationItems | ||||||
|   items = extract_items(initial_data.as_h, author, ucid) | 
 | ||||||
|  |   items = [] of SearchItem | ||||||
|  |   continuationItems.as_a.select(&.as_h.has_key?("itemSectionRenderer")).each { |item| | ||||||
|  |     extract_item(item["itemSectionRenderer"]["contents"].as_a[0]) | ||||||
|  |       .try { |t| items << t } | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   return items.size, items |   return items.size, items | ||||||
| end | end | ||||||
| @ -361,17 +373,28 @@ def produce_search_params(page = 1, sort : String = "relevance", date : String = | |||||||
|   return params |   return params | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| def produce_channel_search_url(ucid, query, page) | def produce_channel_search_continuation(ucid, query, page) | ||||||
|  |   if page <= 1 | ||||||
|  |     idx = 0_i64 | ||||||
|  |   else | ||||||
|  |     idx = 30_i64 * (page - 1) | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   object = { |   object = { | ||||||
|     "80226972:embedded" => { |     "80226972:embedded" => { | ||||||
|       "2:string" => ucid, |       "2:string" => ucid, | ||||||
|       "3:base64" => { |       "3:base64" => { | ||||||
|         "2:string"  => "search", |         "2:string"  => "search", | ||||||
|  |         "6:varint"  => 1_i64, | ||||||
|         "7:varint"  => 1_i64, |         "7:varint"  => 1_i64, | ||||||
|         "15:string" => "#{page}", |         "12:varint" => 1_i64, | ||||||
|  |         "15:base64" => { | ||||||
|  |           "3:varint" => idx, | ||||||
|  |         }, | ||||||
|         "23:varint" => 0_i64, |         "23:varint" => 0_i64, | ||||||
|       }, |       }, | ||||||
|       "11:string" => query, |       "11:string" => query, | ||||||
|  |       "35:string" => "browse-feed#{ucid}search", | ||||||
|     }, |     }, | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| @ -380,7 +403,7 @@ def produce_channel_search_url(ucid, query, page) | |||||||
|     .try { |i| Base64.urlsafe_encode(i) } |     .try { |i| Base64.urlsafe_encode(i) } | ||||||
|     .try { |i| URI.encode_www_form(i) } |     .try { |i| URI.encode_www_form(i) } | ||||||
| 
 | 
 | ||||||
|   return "/browse_ajax?continuation=#{continuation}&gl=US&hl=en" |   return continuation | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| def process_search_query(query, page, user, region) | def process_search_query(query, page, user, region) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user