mirror of
				https://gitea.invidious.io/iv-org/invidious.git
				synced 2024-08-15 00:53:41 +00:00 
			
		
		
		
	Fix 'adaptiveFormats' not available for livestreams in videos API
This commit is contained in:
		
							parent
							
								
									a0f566fef3
								
							
						
					
					
						commit
						0503d2a9f3
					
				
					 2 changed files with 21 additions and 9 deletions
				
			
		|  | @ -62,6 +62,9 @@ module Invidious::Routes::API::Manifest | ||||||
| 
 | 
 | ||||||
|             xml.element("AdaptationSet", id: i, mimeType: mime_type, startWithSAP: 1, subsegmentAlignment: true) do |             xml.element("AdaptationSet", id: i, mimeType: mime_type, startWithSAP: 1, subsegmentAlignment: true) do | ||||||
|               mime_streams.each do |fmt| |               mime_streams.each do |fmt| | ||||||
|  |                 # OFT streams aren't supported yet (See https://github.com/TeamNewPipe/NewPipe/issues/2415) | ||||||
|  |                 next if !(fmt.has_key?("indexRange") && fmt.has_key?("initRange")) | ||||||
|  | 
 | ||||||
|                 codecs = fmt["mimeType"].as_s.split("codecs=")[1].strip('"') |                 codecs = fmt["mimeType"].as_s.split("codecs=")[1].strip('"') | ||||||
|                 bandwidth = fmt["bitrate"].as_i |                 bandwidth = fmt["bitrate"].as_i | ||||||
|                 itag = fmt["itag"].as_i |                 itag = fmt["itag"].as_i | ||||||
|  | @ -90,6 +93,9 @@ module Invidious::Routes::API::Manifest | ||||||
|             heights = [] of Int32 |             heights = [] of Int32 | ||||||
|             xml.element("AdaptationSet", id: i, mimeType: mime_type, startWithSAP: 1, subsegmentAlignment: true, scanType: "progressive") do |             xml.element("AdaptationSet", id: i, mimeType: mime_type, startWithSAP: 1, subsegmentAlignment: true, scanType: "progressive") do | ||||||
|               mime_streams.each do |fmt| |               mime_streams.each do |fmt| | ||||||
|  |                 # OFT streams aren't supported yet (See https://github.com/TeamNewPipe/NewPipe/issues/2415) | ||||||
|  |                 next if !(fmt.has_key?("indexRange") && fmt.has_key?("initRange")) | ||||||
|  | 
 | ||||||
|                 codecs = fmt["mimeType"].as_s.split("codecs=")[1].strip('"') |                 codecs = fmt["mimeType"].as_s.split("codecs=")[1].strip('"') | ||||||
|                 bandwidth = fmt["bitrate"].as_i |                 bandwidth = fmt["bitrate"].as_i | ||||||
|                 itag = fmt["itag"].as_i |                 itag = fmt["itag"].as_i | ||||||
|  |  | ||||||
|  | @ -374,18 +374,25 @@ struct Video | ||||||
|         json.array do |         json.array do | ||||||
|           self.adaptive_fmts.each do |fmt| |           self.adaptive_fmts.each do |fmt| | ||||||
|             json.object do |             json.object do | ||||||
|               json.field "index", "#{fmt["indexRange"]["start"]}-#{fmt["indexRange"]["end"]}" |               # Only available on regular videos, not livestreams/OFT streams | ||||||
|               json.field "bitrate", fmt["bitrate"].as_i.to_s |               if init_range = fmt["initRange"]? | ||||||
|               json.field "init", "#{fmt["initRange"]["start"]}-#{fmt["initRange"]["end"]}" |                 json.field "init", "#{init_range["start"]}-#{init_range["end"]}" | ||||||
|  |               end | ||||||
|  |               if index_range = fmt["indexRange"]? | ||||||
|  |                 json.field "index", "#{index_range["start"]}-#{index_range["end"]}" | ||||||
|  |               end | ||||||
|  | 
 | ||||||
|  |               # Not available on MPEG-4 Timed Text (`text/mp4`) streams (livestreams only) | ||||||
|  |               json.field "bitrate", fmt["bitrate"].as_i.to_s if fmt["bitrate"]? | ||||||
|  | 
 | ||||||
|               json.field "url", fmt["url"] |               json.field "url", fmt["url"] | ||||||
|               json.field "itag", fmt["itag"].as_i.to_s |               json.field "itag", fmt["itag"].as_i.to_s | ||||||
|               json.field "type", fmt["mimeType"] |               json.field "type", fmt["mimeType"] | ||||||
|               json.field "clen", fmt["contentLength"] |               json.field "clen", fmt["contentLength"]? || "-1" | ||||||
|               json.field "lmt", fmt["lastModified"] |               json.field "lmt", fmt["lastModified"] | ||||||
|               json.field "projectionType", fmt["projectionType"] |               json.field "projectionType", fmt["projectionType"] | ||||||
| 
 | 
 | ||||||
|               fmt_info = itag_to_metadata?(fmt["itag"]) |               if fmt_info = itag_to_metadata?(fmt["itag"]) | ||||||
|               if fmt_info |  | ||||||
|                 fps = fmt_info["fps"]?.try &.to_i || fmt["fps"]?.try &.as_i || 30 |                 fps = fmt_info["fps"]?.try &.to_i || fmt["fps"]?.try &.as_i || 30 | ||||||
|                 json.field "fps", fps |                 json.field "fps", fps | ||||||
|                 json.field "container", fmt_info["ext"] |                 json.field "container", fmt_info["ext"] | ||||||
|  | @ -612,6 +619,7 @@ struct Video | ||||||
|       fmt["url"] = JSON::Any.new("#{fmt["url"]}&host=#{URI.parse(fmt["url"].as_s).host}") |       fmt["url"] = JSON::Any.new("#{fmt["url"]}&host=#{URI.parse(fmt["url"].as_s).host}") | ||||||
|       fmt["url"] = JSON::Any.new("#{fmt["url"]}®ion=#{self.info["region"]}") if self.info["region"]? |       fmt["url"] = JSON::Any.new("#{fmt["url"]}®ion=#{self.info["region"]}") if self.info["region"]? | ||||||
|     end |     end | ||||||
|  | 
 | ||||||
|     fmt_stream.sort_by! { |f| f["width"]?.try &.as_i || 0 } |     fmt_stream.sort_by! { |f| f["width"]?.try &.as_i || 0 } | ||||||
|     @fmt_stream = fmt_stream |     @fmt_stream = fmt_stream | ||||||
|     return @fmt_stream.as(Array(Hash(String, JSON::Any))) |     return @fmt_stream.as(Array(Hash(String, JSON::Any))) | ||||||
|  | @ -631,9 +639,7 @@ struct Video | ||||||
|       fmt["url"] = JSON::Any.new("#{fmt["url"]}&host=#{URI.parse(fmt["url"].as_s).host}") |       fmt["url"] = JSON::Any.new("#{fmt["url"]}&host=#{URI.parse(fmt["url"].as_s).host}") | ||||||
|       fmt["url"] = JSON::Any.new("#{fmt["url"]}®ion=#{self.info["region"]}") if self.info["region"]? |       fmt["url"] = JSON::Any.new("#{fmt["url"]}®ion=#{self.info["region"]}") if self.info["region"]? | ||||||
|     end |     end | ||||||
|     # See https://github.com/TeamNewPipe/NewPipe/issues/2415 | 
 | ||||||
|     # Some streams are segmented by URL `sq/` rather than index, for now we just filter them out |  | ||||||
|     fmt_stream.reject! { |f| !f["indexRange"]? } |  | ||||||
|     fmt_stream.sort_by! { |f| f["width"]?.try &.as_i || 0 } |     fmt_stream.sort_by! { |f| f["width"]?.try &.as_i || 0 } | ||||||
|     @adaptive_fmts = fmt_stream |     @adaptive_fmts = fmt_stream | ||||||
|     return @adaptive_fmts.as(Array(Hash(String, JSON::Any))) |     return @adaptive_fmts.as(Array(Hash(String, JSON::Any))) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue