aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/web/common_api/common_api.ex4
-rw-r--r--lib/pleroma/web/twitter_api/views/activity_view.ex50
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)