Merge branch 'feature/mastodon-api-for-tootstream' into 'develop'
authorlambda <pleromagit@rogerbraun.net>
Sun, 8 Apr 2018 06:02:11 +0000 (06:02 +0000)
committerlambda <pleromagit@rogerbraun.net>
Sun, 8 Apr 2018 06:02:11 +0000 (06:02 +0000)
mastodon api emulation improvements for tootstream

Closes #101

See merge request pleroma/pleroma!100

1  2 
lib/pleroma/web/mastodon_api/mastodon_api_controller.ex
lib/pleroma/web/router.ex

index 97a618186388fc303205f4d8922b83e6d93da6a0,f1cb6ec9dafd342fbe4d20625e720309540262a8..b00f1e15c1a58506e02f597fb4b821f7c9040410
@@@ -102,13 -102,14 +102,14 @@@ defmodule Pleroma.Web.MastodonAPI.Masto
    end
  
    @instance Application.get_env(:pleroma, :instance)
+   @mastodon_api_level "2.3.3"
  
    def masto_instance(conn, _params) do
      response = %{
        uri: Web.base_url(),
        title: Keyword.get(@instance, :name),
        description: "A Pleroma instance, an alternative fediverse server",
-       version: Keyword.get(@instance, :version),
+       version: "#{@mastodon_api_level} (compatible; #{Keyword.get(@instance, :version)})",
        email: Keyword.get(@instance, :email),
        urls: %{
          streaming_api: String.replace(Web.base_url(), ["http", "https"], "wss")
                "video\/mp4"
              ]
            },
 -          settings: %{
 +          settings: Map.get(user.info, "settings") || %{
              onboarded: true,
              home: %{
                shows: %{
      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})
index a33d03fc99714972033ec091afeb8b5a15c2b052,f240077843348c4d702a1d740d47400469c49997..8ee27e63c08b77c59fc9742b901d56ec08834a96
@@@ -100,6 -100,7 +100,7 @@@ defmodule Pleroma.Web.Router d
      get("/domain_blocks", MastodonAPIController, :empty_array)
      get("/follow_requests", MastodonAPIController, :empty_array)
      get("/mutes", MastodonAPIController, :empty_array)
+     get("/lists", MastodonAPIController, :empty_array)
  
      get("/timelines/home", MastodonAPIController, :home_timeline)
  
      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)