forked from AkkomaGang/akkoma
MastoAPI: Persist frontend timelines and settings.
This commit is contained in:
parent
d41bfd1d47
commit
7c47534970
2 changed files with 19 additions and 1 deletions
|
@ -603,7 +603,7 @@ def index(%{assigns: %{user: user}} = conn, _params) do
|
|||
"video\/mp4"
|
||||
]
|
||||
},
|
||||
settings: %{
|
||||
settings: Map.get(user.info, "settings") || %{
|
||||
onboarded: true,
|
||||
home: %{
|
||||
shows: %{
|
||||
|
@ -648,6 +648,18 @@ def index(%{assigns: %{user: user}} = conn, _params) do
|
|||
end
|
||||
end
|
||||
|
||||
def put_settings(%{assigns: %{user: user}} = conn, %{"data" => settings} = _params) do
|
||||
with new_info <- Map.put(user.info, "settings", settings),
|
||||
change <- User.info_changeset(user, %{info: new_info}),
|
||||
{:ok, _user} <- User.update_and_set_cache(change) do
|
||||
conn
|
||||
|> json(%{})
|
||||
else e ->
|
||||
conn
|
||||
|> json(%{error: inspect(e)})
|
||||
end
|
||||
end
|
||||
|
||||
def login(conn, _) do
|
||||
conn
|
||||
|> render(MastodonView, "login.html", %{error: false})
|
||||
|
|
|
@ -120,6 +120,12 @@ def user_fetcher(username) do
|
|||
post("/media", MastodonAPIController, :upload)
|
||||
end
|
||||
|
||||
scope "/api/web", Pleroma.Web.MastodonAPI do
|
||||
pipe_through(:authenticated_api)
|
||||
|
||||
put("/settings", MastodonAPIController, :put_settings)
|
||||
end
|
||||
|
||||
scope "/api/v1", Pleroma.Web.MastodonAPI do
|
||||
pipe_through(:api)
|
||||
get("/instance", MastodonAPIController, :masto_instance)
|
||||
|
|
Loading…
Reference in a new issue