From 75b49d4e8394b721d61ee1ec41fdce4e7ba95d4c Mon Sep 17 00:00:00 2001 From: lekma Date: Wed, 30 Oct 2024 06:15:43 +0000 Subject: [PATCH] allow api endpoint '/api/v1/auth/tokens/register' to answer json requests with json response --- src/invidious/routes/api/v1/authenticated.cr | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/invidious/routes/api/v1/authenticated.cr b/src/invidious/routes/api/v1/authenticated.cr index a35d2f2b2..a5d093176 100644 --- a/src/invidious/routes/api/v1/authenticated.cr +++ b/src/invidious/routes/api/v1/authenticated.cr @@ -398,7 +398,8 @@ module Invidious::Routes::API::V1::Authenticated user = env.get("user").as(User) locale = env.get("preferences").as(Preferences).locale - case env.request.headers["Content-Type"]? + content_type = env.request.headers["Content-Type"]? + case content_type when "application/x-www-form-urlencoded" scopes = env.params.body.select { |k, _| k.match(/^scopes\[\d+\]$/) }.map { |_, v| v } callback_url = env.params.body["callbackUrl"]? @@ -419,7 +420,7 @@ module Invidious::Routes::API::V1::Authenticated callback_url = URI.parse(callback_url) end - if sid = env.get?("sid").try &.as(String) + if sid = env.get?("sid").try &.as(String) && content_type != "application/json" env.response.content_type = "text/html" csrf_token = generate_response(sid, {":authorize_token"}, HMAC_KEY, use_nonce: true)