use Pleroma.Web, :controller
alias Pleroma.Web.TwitterAPI.{TwitterAPI, UserView}
alias Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter
- alias Pleroma.{Repo, Activity, User}
+ alias Pleroma.Web.CommonAPI
+ alias Pleroma.{Repo, Activity, User, Object}
alias Pleroma.Web.ActivityPub.ActivityPub
alias Ecto.Changeset
end
end
+ def delete_post(%{assigns: %{user: user}} = conn, %{"id" => id}) do
+ with {:ok, delete} <- CommonAPI.delete(id, user) do
+ json = ActivityRepresenter.to_json(delete, %{user: user, for: user})
+ conn
+ |> json_reply(200, json)
+ end
+ end
+
def unfollow(%{assigns: %{user: user}} = conn, params) do
case TwitterAPI.unfollow(user, params) do
{:ok, user, unfollowed} ->
render(conn, UserView, "show.json", %{user: user, for: user})
end
+ def update_banner(%{assigns: %{user: user}} = conn, params) do
+ with {:ok, object} <- ActivityPub.upload(%{"img" => params["banner"]}),
+ new_info <- Map.put(user.info, "banner", object.data),
+ change <- User.info_changeset(user, %{info: new_info}),
+ {:ok, user} <- Repo.update(change) do
+ %{"url" => [ %{ "href" => href } | t ]} = object.data
+ response = %{ url: href } |> Poison.encode!
+ conn
+ |> json_reply(200, response)
+ end
+ end
+
+ def update_background(%{assigns: %{user: user}} = conn, params) do
+ with {:ok, object} <- ActivityPub.upload(params),
+ new_info <- Map.put(user.info, "background", object.data),
+ change <- User.info_changeset(user, %{info: new_info}),
+ {:ok, user} <- Repo.update(change) do
+ %{"url" => [ %{ "href" => href } | t ]} = object.data
+ response = %{ url: href } |> Poison.encode!
+ conn
+ |> json_reply(200, response)
+ end
+ end
+
def external_profile(%{assigns: %{user: current_user}} = conn, %{"profileurl" => uri}) do
with {:ok, user_map} <- TwitterAPI.get_external_profile(current_user, uri),
response <- Poison.encode!(user_map) do
end
def update_profile(%{assigns: %{user: user}} = conn, params) do
- if bio = params["description"] do
- params = Map.put(params, "bio", bio)
+ params = if bio = params["description"] do
+ Map.put(params, "bio", bio)
+ else
+ params
end
with changeset <- User.update_changeset(user, params),