mirror of
https://github.com/iv-org/invidious.git
synced 2024-10-01 01:35:38 -04:00
Merge pull request #1406 from Perflyst/channel-api-v3
Use channel API v3
This commit is contained in:
commit
17e0207120
@ -402,14 +402,9 @@ def produce_channel_videos_url(ucid, page = 1, auto_generated = nil, sort_by = "
|
|||||||
object["80226972:embedded"]["3:base64"].as(Hash)["4:varint"] = 0_i64
|
object["80226972:embedded"]["3:base64"].as(Hash)["4:varint"] = 0_i64
|
||||||
|
|
||||||
object["80226972:embedded"]["3:base64"].as(Hash)["61:string"] = Base64.urlsafe_encode(Protodec::Any.from_json(Protodec::Any.cast_json({
|
object["80226972:embedded"]["3:base64"].as(Hash)["61:string"] = Base64.urlsafe_encode(Protodec::Any.from_json(Protodec::Any.cast_json({
|
||||||
"1:embedded" => {
|
"1:string" => Base64.urlsafe_encode(Protodec::Any.from_json(Protodec::Any.cast_json({
|
||||||
"1:varint" => 6307666885028338688_i64,
|
"1:varint" => 30_i64 * (page - 1),
|
||||||
"2:embedded" => {
|
}))),
|
||||||
"1:string" => Base64.urlsafe_encode(Protodec::Any.from_json(Protodec::Any.cast_json({
|
|
||||||
"1:varint" => 30_i64 * (page - 1),
|
|
||||||
}))),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})))
|
})))
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -890,20 +885,8 @@ def get_about_info(ucid, locale)
|
|||||||
end
|
end
|
||||||
|
|
||||||
def get_channel_videos_response(ucid, page = 1, auto_generated = nil, sort_by = "newest")
|
def get_channel_videos_response(ucid, page = 1, auto_generated = nil, sort_by = "newest")
|
||||||
url = produce_channel_videos_url(ucid, page, auto_generated: auto_generated, sort_by: sort_by, v2: false)
|
url = produce_channel_videos_url(ucid, page, auto_generated: auto_generated, sort_by: sort_by, v2: true)
|
||||||
response = YT_POOL.client &.get(url)
|
return YT_POOL.client &.get(url)
|
||||||
initial_data = JSON.parse(response.body).as_a.find &.["response"]?
|
|
||||||
return response if !initial_data
|
|
||||||
needs_v2 = initial_data
|
|
||||||
.try &.["response"]?.try &.["alerts"]?
|
|
||||||
.try &.as_a.any? { |alert|
|
|
||||||
alert.try &.["alertRenderer"]?.try &.["type"]?.try { |t| t == "ERROR" }
|
|
||||||
}
|
|
||||||
if needs_v2
|
|
||||||
url = produce_channel_videos_url(ucid, page, auto_generated: auto_generated, sort_by: sort_by, v2: true)
|
|
||||||
response = YT_POOL.client &.get(url)
|
|
||||||
end
|
|
||||||
response
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def get_60_videos(ucid, author, page, auto_generated, sort_by = "newest")
|
def get_60_videos(ucid, author, page, auto_generated, sort_by = "newest")
|
||||||
|
Loading…
Reference in New Issue
Block a user