logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma
commit: 9a2d3705c69ed4acd97d423013d29f8d5d608f94
parent: 8f9bcc4ab0b16efa9168f49f6e2cc14bc424d398
Author: lambda <pleromagit@rogerbraun.net>
Date:   Sun,  8 Apr 2018 06:01:06 +0000

Merge branch 'fix/persisted-mastofe-settings' into 'develop'

MastoAPI: Persist frontend timelines and settings.

Closes #113

See merge request pleroma/pleroma!98

Diffstat:

Mlib/pleroma/web/mastodon_api/mastodon_api_controller.ex14+++++++++++++-
Mlib/pleroma/web/router.ex6++++++
2 files changed, 19 insertions(+), 1 deletion(-)

diff --git a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex @@ -604,7 +604,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do "video\/mp4" ] }, - settings: %{ + settings: Map.get(user.info, "settings") || %{ onboarded: true, home: %{ shows: %{ @@ -649,6 +649,18 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController 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}) diff --git a/lib/pleroma/web/router.ex b/lib/pleroma/web/router.ex @@ -120,6 +120,12 @@ defmodule Pleroma.Web.Router 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)