diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/pleroma/web/common_api/common_api.ex | 4 | ||||
-rw-r--r-- | lib/pleroma/web/twitter_api/views/activity_view.ex | 50 |
2 files changed, 52 insertions, 2 deletions
diff --git a/lib/pleroma/web/common_api/common_api.ex b/lib/pleroma/web/common_api/common_api.ex index 0f84542f0..5fc940261 100644 --- a/lib/pleroma/web/common_api/common_api.ex +++ b/lib/pleroma/web/common_api/common_api.ex @@ -46,8 +46,8 @@ defmodule Pleroma.Web.CommonAPI do end end - def get_visibility(%{"visibility" => visibility}), do: visibility - def get_visibility(%{"in_reply_to_status_id" => status_id}) when status_id do + def get_visibility(%{"visibility" => visibility}) when visibility in ~w{public unlisted private direct}, do: visibility + def get_visibility(%{"in_reply_to_status_id" => status_id}) when not is_nil(status_id) do inReplyTo = get_replied_to_activity(status_id) Pleroma.Web.MastodonAPI.StatusView.get_visibility(inReplyTo.data["object"]) end diff --git a/lib/pleroma/web/twitter_api/views/activity_view.ex b/lib/pleroma/web/twitter_api/views/activity_view.ex index ae5be60ce..50d536d0e 100644 --- a/lib/pleroma/web/twitter_api/views/activity_view.ex +++ b/lib/pleroma/web/twitter_api/views/activity_view.ex @@ -5,8 +5,58 @@ defmodule Pleroma.Web.TwitterAPI.ActivityView do alias Pleroma.Web.TwitterAPI.UserView alias Pleroma.Web.TwitterAPI.TwitterAPI alias Pleroma.Web.TwitterAPI.Representers.ObjectRepresenter + alias Pleroma.Activity alias Pleroma.Formatter + def render("activity.json", %{activity: %{data: %{"type" => "Announce"}} = activity} = opts) do + user = User.get_by_ap_id(activity.data["actor"]) + created_at = activity.data["published"] |> Utils.date_to_asctime + announced_activity = Activity.get_create_activity_by_object_ap_id(activity.data["object"]) + + text = "#{user.nickname} retweeted a status." + + # retweeted_status = to_map(announced_activity, Map.merge(%{user: announced_user}, opts)) + retweeted_status = render("activity.json", Map.merge(opts, %{activity: announced_activity})) + + %{ + "id" => activity.id, + "user" => UserView.render("show.json", %{user: user, for: opts[:for]}), + "statusnet_html" => text, + "text" => text, + "is_local" => activity.local, + "is_post_verb" => false, + "uri" => "tag:#{activity.data["id"]}:objectType=note", + "created_at" => created_at, + "retweeted_status" => retweeted_status, + "statusnet_conversation_id" => conversation_id(announced_activity), + "external_url" => activity.data["id"], + "activity_type" => "repeat" + } + end + + def render("activity.json", %{activity: %{data: %{"type" => "Like"}} = activity} = opts) do + user = User.get_cached_by_ap_id(activity.data["actor"]) + liked_activity = Activity.get_create_activity_by_object_ap_id(activity.data["object"]) + created_at = activity.data["published"] + |> Utils.date_to_asctime + + text = "#{user.nickname} favorited a status." + + %{ + "id" => activity.id, + "user" => UserView.render("show.json", %{user: user, for: opts[:for]}), + "statusnet_html" => text, + "text" => text, + "is_local" => activity.local, + "is_post_verb" => false, + "uri" => "tag:#{activity.data["id"]}:objectType=Favourite", + "created_at" => created_at, + "in_reply_to_status_id" => liked_activity.id, + "external_url" => activity.data["id"], + "activity_type" => "like" + } + end + def render("activity.json", %{activity: %{data: %{"type" => "Create", "object" => object}} = activity} = opts) do actor = get_in(activity.data, ["actor"]) user = User.get_cached_by_ap_id(actor) |