mirror of
https://github.com/iv-org/invidious.git
synced 2024-12-31 17:37:38 +01:00
Add GET '/authorize_token'
This commit is contained in:
parent
97ef2191fd
commit
e119459411
@ -127,6 +127,7 @@ if CONFIG.check_tables
|
|||||||
end
|
end
|
||||||
|
|
||||||
# Start jobs
|
# Start jobs
|
||||||
|
|
||||||
refresh_channels(PG_DB, logger, config.channel_threads, config.full_refresh)
|
refresh_channels(PG_DB, logger, config.channel_threads, config.full_refresh)
|
||||||
refresh_feeds(PG_DB, logger, config.feed_threads)
|
refresh_feeds(PG_DB, logger, config.feed_threads)
|
||||||
subscribe_to_feeds(PG_DB, logger, HMAC_KEY, config)
|
subscribe_to_feeds(PG_DB, logger, HMAC_KEY, config)
|
||||||
@ -1683,44 +1684,10 @@ post "/subscription_ajax" do |env|
|
|||||||
channel_id ||= ""
|
channel_id ||= ""
|
||||||
|
|
||||||
if !user.password
|
if !user.password
|
||||||
headers = HTTP::Headers.new
|
|
||||||
headers["Cookie"] = env.request.headers["Cookie"]
|
|
||||||
|
|
||||||
client = make_client(YT_URL)
|
|
||||||
html = client.get("/subscription_manager?disable_polymer=1", headers)
|
|
||||||
|
|
||||||
cookies = HTTP::Cookies.from_headers(headers)
|
|
||||||
html.cookies.each do |cookie|
|
|
||||||
if {"VISITOR_INFO1_LIVE", "YSC", "SIDCC"}.includes? cookie.name
|
|
||||||
if cookies[cookie.name]?
|
|
||||||
cookies[cookie.name] = cookie
|
|
||||||
else
|
|
||||||
cookies << cookie
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
headers = cookies.add_request_headers(headers)
|
|
||||||
|
|
||||||
match = html.body.match(/'XSRF_TOKEN': "(?<session_token>[A-Za-z0-9\_\-\=]+)"/)
|
|
||||||
if match
|
|
||||||
session_token = match["session_token"]
|
|
||||||
else
|
|
||||||
next env.redirect referer
|
|
||||||
end
|
|
||||||
|
|
||||||
headers["content-type"] = "application/x-www-form-urlencoded"
|
|
||||||
|
|
||||||
post_req = {
|
|
||||||
"session_token" => session_token,
|
|
||||||
}
|
|
||||||
post_url = "/subscription_ajax?#{action}=1&c=#{channel_id}"
|
|
||||||
|
|
||||||
# Sync subscriptions with YouTube
|
# Sync subscriptions with YouTube
|
||||||
client.post(post_url, headers, form: post_req)
|
subscribe_ajax(channel_id, action, env.request.headers)
|
||||||
email = user.email
|
|
||||||
else
|
|
||||||
email = user.email
|
|
||||||
end
|
end
|
||||||
|
email = user.email
|
||||||
|
|
||||||
case action
|
case action
|
||||||
when .starts_with? "action_create"
|
when .starts_with? "action_create"
|
||||||
@ -2158,10 +2125,33 @@ post "/clear_watch_history" do |env|
|
|||||||
env.redirect referer
|
env.redirect referer
|
||||||
end
|
end
|
||||||
|
|
||||||
# TODO?
|
get "/authorize_token" do |env|
|
||||||
# get "/authorize_token" do |env|
|
locale = LOCALES[env.get("preferences").as(Preferences).locale]?
|
||||||
# ...
|
|
||||||
# end
|
user = env.get? "user"
|
||||||
|
sid = env.get? "sid"
|
||||||
|
referer = get_referer(env)
|
||||||
|
|
||||||
|
if user
|
||||||
|
user = user.as(User)
|
||||||
|
sid = sid.as(String)
|
||||||
|
csrf_token = generate_response(sid, {":authorize_token"}, HMAC_KEY, PG_DB)
|
||||||
|
|
||||||
|
scopes = env.params.query["scopes"]?.try &.split(",")
|
||||||
|
scopes ||= [] of String
|
||||||
|
|
||||||
|
callback_url = env.params.query["callback_url"]?
|
||||||
|
if callback_url
|
||||||
|
callback_url = URI.parse(callback_url)
|
||||||
|
end
|
||||||
|
|
||||||
|
expire = env.params.query["expire"]?.try &.to_i?
|
||||||
|
|
||||||
|
templated "authorize_token"
|
||||||
|
else
|
||||||
|
env.redirect referer
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
post "/authorize_token" do |env|
|
post "/authorize_token" do |env|
|
||||||
locale = LOCALES[env.get("preferences").as(Preferences).locale]?
|
locale = LOCALES[env.get("preferences").as(Preferences).locale]?
|
||||||
@ -4579,6 +4569,10 @@ post "/api/v1/auth/subscriptions/:ucid" do |env|
|
|||||||
PG_DB.exec("UPDATE users SET subscriptions = array_append(subscriptions,$1) WHERE email = $2", ucid, user.email)
|
PG_DB.exec("UPDATE users SET subscriptions = array_append(subscriptions,$1) WHERE email = $2", ucid, user.email)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# For Google accounts, access tokens don't have enough information to
|
||||||
|
# make a request on the user's behalf, which is why we don't sync with
|
||||||
|
# YouTube.
|
||||||
|
|
||||||
env.response.status_code = 204
|
env.response.status_code = 204
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -4600,11 +4594,6 @@ get "/api/v1/auth/tokens" do |env|
|
|||||||
|
|
||||||
tokens = PG_DB.query_all("SELECT id, issued FROM session_ids WHERE email = $1", user.email, as: {session: String, issued: Time})
|
tokens = PG_DB.query_all("SELECT id, issued FROM session_ids WHERE email = $1", user.email, as: {session: String, issued: Time})
|
||||||
|
|
||||||
# Only allow user sessions to view other user sessions
|
|
||||||
# if !scopes.includes? [":*"]
|
|
||||||
# tokens.select { |token| token[:session].starts_with? "v1:" }
|
|
||||||
# end
|
|
||||||
|
|
||||||
JSON.build do |json|
|
JSON.build do |json|
|
||||||
json.array do
|
json.array do
|
||||||
tokens.each do |token|
|
tokens.each do |token|
|
||||||
|
@ -269,3 +269,36 @@ def generate_text_captcha(key, db)
|
|||||||
tokens: tokens,
|
tokens: tokens,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def subscribe_ajax(channel_id, action, env_headers)
|
||||||
|
headers = HTTP::Headers.new
|
||||||
|
headers["Cookie"] = env_headers["Cookie"]
|
||||||
|
|
||||||
|
client = make_client(YT_URL)
|
||||||
|
html = client.get("/subscription_manager?disable_polymer=1", headers)
|
||||||
|
|
||||||
|
cookies = HTTP::Cookies.from_headers(headers)
|
||||||
|
html.cookies.each do |cookie|
|
||||||
|
if {"VISITOR_INFO1_LIVE", "YSC", "SIDCC"}.includes? cookie.name
|
||||||
|
if cookies[cookie.name]?
|
||||||
|
cookies[cookie.name] = cookie
|
||||||
|
else
|
||||||
|
cookies << cookie
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
headers = cookies.add_request_headers(headers)
|
||||||
|
|
||||||
|
if match = html.body.match(/'XSRF_TOKEN': "(?<session_token>[A-Za-z0-9\_\-\=]+)"/)
|
||||||
|
session_token = match["session_token"]
|
||||||
|
|
||||||
|
headers["content-type"] = "application/x-www-form-urlencoded"
|
||||||
|
|
||||||
|
post_req = {
|
||||||
|
"session_token" => session_token,
|
||||||
|
}
|
||||||
|
post_url = "/subscription_ajax?#{action}=1&c=#{channel_id}"
|
||||||
|
|
||||||
|
client.post(post_url, headers, form: post_req)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user