summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--docker/Dockerfile7
-rw-r--r--src/invidious.cr2
-rw-r--r--src/invidious/helpers/errors.cr2
-rw-r--r--src/invidious/playlists.cr24
4 files changed, 21 insertions, 14 deletions
diff --git a/docker/Dockerfile b/docker/Dockerfile
index d93f2868..ce4cc765 100644
--- a/docker/Dockerfile
+++ b/docker/Dockerfile
@@ -4,12 +4,7 @@ WORKDIR /invidious
COPY ./shard.yml ./shard.yml
COPY ./shard.lock ./shard.lock
RUN shards install && \
- # TODO: Document build instructions
- # See https://github.com/omarroth/boringssl-alpine/blob/master/APKBUILD,
- # https://github.com/omarroth/lsquic-alpine/blob/master/APKBUILD,
- # https://github.com/omarroth/lsquic.cr/issues/1#issuecomment-631610081
- # for details building static lib
- curl -Lo ./lib/lsquic/src/lsquic/ext/liblsquic.a https://omar.yt/lsquic/liblsquic-v2.18.1.a
+ curl -Lo ./lib/lsquic/src/lsquic/ext/liblsquic.a https://github.com/iv-org/lsquic-static-alpine/releases/download/v2.18.1/liblsquic.a
COPY ./src/ ./src/
# TODO: .git folder is required for building – this is destructive.
# See definition of CURRENT_BRANCH, CURRENT_COMMIT and CURRENT_VERSION.
diff --git a/src/invidious.cr b/src/invidious.cr
index dd862e23..5d19acf1 100644
--- a/src/invidious.cr
+++ b/src/invidious.cr
@@ -2623,6 +2623,8 @@ end
begin
playlist = get_playlist(PG_DB, plid, locale)
+ rescue ex : InfoException
+ next error_json(404, ex)
rescue ex
next error_json(404, "Playlist does not exist.")
end
diff --git a/src/invidious/helpers/errors.cr b/src/invidious/helpers/errors.cr
index 4487ff8c..2c62d44b 100644
--- a/src/invidious/helpers/errors.cr
+++ b/src/invidious/helpers/errors.cr
@@ -26,6 +26,7 @@ def error_template_helper(env : HTTP::Server::Context, config : Config, locale :
if exception.is_a?(InfoException)
return error_template_helper(env, config, locale, status_code, exception.message || "")
end
+ env.response.content_type = "text/html"
env.response.status_code = status_code
issue_template = %(Title: `#{exception.message} (#{exception.class})`)
issue_template += %(\nDate: `#{Time::Format::ISO_8601_DATE_TIME.format(Time.utc)}`)
@@ -43,6 +44,7 @@ def error_template_helper(env : HTTP::Server::Context, config : Config, locale :
end
def error_template_helper(env : HTTP::Server::Context, config : Config, locale : Hash(String, JSON::Any) | Nil, status_code : Int32, message : String)
+ env.response.content_type = "text/html"
env.response.status_code = status_code
error_message = translate(locale, message)
return templated "error"
diff --git a/src/invidious/playlists.cr b/src/invidious/playlists.cr
index d5b41caa..25797a36 100644
--- a/src/invidious/playlists.cr
+++ b/src/invidious/playlists.cr
@@ -365,9 +365,13 @@ def fetch_playlist(plid, locale)
end
initial_data = extract_initial_data(response.body)
- playlist_info = initial_data["sidebar"]?.try &.["playlistSidebarRenderer"]?.try &.["items"]?.try &.[0]["playlistSidebarPrimaryInfoRenderer"]?
+ playlist_sidebar_renderer = initial_data["sidebar"]?.try &.["playlistSidebarRenderer"]?.try &.["items"]?
+ raise InfoException.new("Could not extract playlistSidebarRenderer.") if !playlist_sidebar_renderer
+
+ playlist_info = playlist_sidebar_renderer[0]["playlistSidebarPrimaryInfoRenderer"]?
raise InfoException.new("Could not extract playlist info") if !playlist_info
+
title = playlist_info["title"]?.try &.["runs"][0]?.try &.["text"]?.try &.as_s || ""
desc_item = playlist_info["description"]?
@@ -392,14 +396,18 @@ def fetch_playlist(plid, locale)
end
end
- author_info = initial_data["sidebar"]?.try &.["playlistSidebarRenderer"]?.try &.["items"]?.try &.[1]["playlistSidebarSecondaryInfoRenderer"]?
- .try &.["videoOwner"]["videoOwnerRenderer"]?
-
- raise InfoException.new("Could not extract author info") if !author_info
+ if playlist_sidebar_renderer.size < 2
+ author = ""
+ author_thumbnail = ""
+ ucid = ""
+ else
+ author_info = playlist_sidebar_renderer[1]["playlistSidebarSecondaryInfoRenderer"]?.try &.["videoOwner"]["videoOwnerRenderer"]?
+ raise InfoException.new("Could not extract author info") if !author_info
- author_thumbnail = author_info["thumbnail"]["thumbnails"][0]["url"]?.try &.as_s || ""
- author = author_info["title"]["runs"][0]["text"]?.try &.as_s || ""
- ucid = author_info["title"]["runs"][0]["navigationEndpoint"]["browseEndpoint"]["browseId"]?.try &.as_s || ""
+ author = author_info["title"]["runs"][0]["text"]?.try &.as_s || ""
+ author_thumbnail = author_info["thumbnail"]["thumbnails"][0]["url"]?.try &.as_s || ""
+ ucid = author_info["title"]["runs"][0]["navigationEndpoint"]["browseEndpoint"]["browseId"]?.try &.as_s || ""
+ end
return Playlist.new({
title: title,