Keep using the existing logic where it already works correctly.

These states are:
* All pages when sorted by 'newest'.
* All pages when sorted by 'popular'
* Page 1 when sorted by 'oldest'.

If not in either of these three states, e.g. page 2 when sorted by 
'oldest', fallback to using the new db/iteration logic.
This commit is contained in:
0x24d 2021-11-20 12:10:59 +00:00
parent dce70e2d93
commit 8e3b8da285

View file

@ -61,8 +61,9 @@ def get_channel_videos_response(ucid, page = 1, auto_generated = nil, sort_by =
continuation = "" continuation = ""
initial_data = Hash(String, JSON::Any).new initial_data = Hash(String, JSON::Any).new
if page == 1 # Manually generating the continuation works correctly for both 'newest' and 'popular' sort modes,
# Always manually create the continuation for page 1 as this is likely faster than a db lookup. # and for page 1 when sorting by 'oldest'. So only fallback to using the db if not in either of these states.
if sort_by != "oldest" || page == 1
continuation = produce_channel_videos_continuation(ucid, page, auto_generated: auto_generated, sort_by: sort_by, v2: true) continuation = produce_channel_videos_continuation(ucid, page, auto_generated: auto_generated, sort_by: sort_by, v2: true)
elsif channel_continuation = PG_DB.query_one?("SELECT * FROM channel_continuations WHERE id = $1 AND page = $2 AND sort_by = $3", ucid, page, sort_by, as: ChannelContinuation) elsif channel_continuation = PG_DB.query_one?("SELECT * FROM channel_continuations WHERE id = $1 AND page = $2 AND sort_by = $3", ucid, page, sort_by, as: ChannelContinuation)
continuation = channel_continuation.continuation continuation = channel_continuation.continuation
@ -111,18 +112,22 @@ def get_channel_videos_response(ucid, page = 1, auto_generated = nil, sort_by =
# Get the wanted page and store the returned continuation for the next page, # Get the wanted page and store the returned continuation for the next page,
# if there is one, so that it can be used the next time this function is called requesting that page. # if there is one, so that it can be used the next time this function is called requesting that page.
initial_data = YoutubeAPI.browse(continuation) initial_data = YoutubeAPI.browse(continuation)
continuation = fetch_continuation_token(initial_data)
if !continuation.nil? && !continuation.empty? # Only get the continuation and store it if the sort mode is 'oldest'.
channel_continuation = ChannelContinuation.new({ if sort_by == "oldest"
id: ucid, continuation = fetch_continuation_token(initial_data)
page: page + 1,
sort_by: sort_by, if !continuation.nil? && !continuation.empty?
continuation: continuation channel_continuation = ChannelContinuation.new({
}) id: ucid,
PG_DB.exec("INSERT INTO channel_continuations VALUES ($1, $2, $3, $4) \ page: page + 1,
ON CONFLICT (id, page, sort_by) DO UPDATE SET continuation = $4", *channel_continuation.to_tuple) sort_by: sort_by,
end continuation: continuation
})
PG_DB.exec("INSERT INTO channel_continuations VALUES ($1, $2, $3, $4) \
ON CONFLICT (id, page, sort_by) DO UPDATE SET continuation = $4", *channel_continuation.to_tuple)
end
end
end end
return initial_data return initial_data