aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/twitter_api/twitter_api.ex
diff options
context:
space:
mode:
Diffstat (limited to 'lib/pleroma/web/twitter_api/twitter_api.ex')
-rw-r--r--lib/pleroma/web/twitter_api/twitter_api.ex25
1 files changed, 21 insertions, 4 deletions
diff --git a/lib/pleroma/web/twitter_api/twitter_api.ex b/lib/pleroma/web/twitter_api/twitter_api.ex
index 58fd51a62..b98283248 100644
--- a/lib/pleroma/web/twitter_api/twitter_api.ex
+++ b/lib/pleroma/web/twitter_api/twitter_api.ex
@@ -1,11 +1,12 @@
defmodule Pleroma.Web.TwitterAPI.TwitterAPI do
- alias Pleroma.User
+ alias Pleroma.{User, Activity, Repo}
alias Pleroma.Web.ActivityPub.ActivityPub
- alias Pleroma.Repo
alias Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter
def create_status(user = %User{}, data = %{}) do
date = DateTime.utc_now() |> DateTime.to_iso8601
+
+ context = ActivityPub.generate_context_id
activity = %{
"type" => "Create",
"to" => [
@@ -16,11 +17,27 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPI do
"object" => %{
"type" => "Note",
"content" => data["status"],
- "published" => date
+ "published" => date,
+ "context" => context
},
- "published" => date
+ "published" => date,
+ "context" => context
}
+ # Wire up reply info.
+ activity = with inReplyToId when not is_nil(inReplyToId) <- data["in_reply_to_status_id"],
+ inReplyTo <- Repo.get(Activity, inReplyToId),
+ context <- inReplyTo.data["context"]
+ do
+ activity
+ |> put_in(["context"], context)
+ |> put_in(["object", "context"], context)
+ |> put_in(["object", "inReplyTo"], inReplyTo.data["object"]["id"])
+ |> put_in(["object", "inReplyToStatusId"], inReplyToId)
+ else _e ->
+ activity
+ end
+
ActivityPub.insert(activity)
end