mirror of
https://framagit.org/framasoft/mobilizon.git
synced 2025-01-03 22:05:00 +00:00
57662aa690
Mostly handle things properly when the front-end is missing Signed-off-by: Thomas Citharel <tcit@tcit.fr>
34 lines
1.1 KiB
Elixir
34 lines
1.1 KiB
Elixir
defmodule Mobilizon.Web.AuthView do
|
|
@moduledoc """
|
|
View for the auth routes
|
|
"""
|
|
|
|
use Mobilizon.Web, :view
|
|
alias Mobilizon.Service.Metadata.Instance
|
|
alias Phoenix.HTML.Tag
|
|
import Mobilizon.Web.Views.Utils
|
|
|
|
def render("callback.html", %{
|
|
conn: conn,
|
|
access_token: access_token,
|
|
refresh_token: refresh_token,
|
|
user: %{id: user_id, email: user_email, role: user_role, default_actor_id: user_actor_id}
|
|
}) do
|
|
info_tags = [
|
|
Tag.tag(:meta, name: "auth-access-token", content: access_token),
|
|
Tag.tag(:meta, name: "auth-refresh-token", content: refresh_token),
|
|
Tag.tag(:meta, name: "auth-user-id", content: user_id),
|
|
Tag.tag(:meta, name: "auth-user-email", content: user_email),
|
|
Tag.tag(:meta, name: "auth-user-role", content: user_role),
|
|
Tag.tag(:meta, name: "auth-user-actor-id", content: user_actor_id)
|
|
]
|
|
|
|
with tags <- Instance.build_tags() ++ info_tags,
|
|
{:ok, html} <- inject_tags(tags, get_locale(conn)) do
|
|
html
|
|
else
|
|
{:error, error} ->
|
|
return_error(conn, error)
|
|
end
|
|
end
|
|
end
|