- def create_status(user = %User{}, data = %{"status" => status}) do
- attachments = attachments_from_ids(data["media_ids"])
- context = ActivityPub.generate_context_id
- mentions = parse_mentions(status)
- content_html = format_input(status, mentions)
- to = to_for_user_and_mentions(user, mentions)
- date = make_date()
-
- inReplyTo = get_replied_to_activity(data["in_reply_to_status_id"])
-
- # Wire up reply info.
- [to, context, object, additional] =
- if inReplyTo do
- context = inReplyTo.data["context"]
- to = to ++ [inReplyTo.data["actor"]]
-
- object = %{
- "type" => "Note",
- "to" => to,
- "content" => content_html,
- "published" => date,
- "context" => context,
- "attachment" => attachments,
- "actor" => user.ap_id,
- "inReplyTo" => inReplyTo.data["object"]["id"],
- "inReplyToStatusId" => inReplyTo.id,
- }
- additional = %{}
-
- [to, context, object, additional]
- else
- object = %{
- "type" => "Note",
- "to" => to,
- "content" => content_html,
- "published" => date,
- "context" => context,
- "attachment" => attachments,
- "actor" => user.ap_id
- }
- [to, context, object, %{}]
+ def create_status(%User{} = user, %{"status" => status} = data) do
+ with attachments <- attachments_from_ids(data["media_ids"]),
+ mentions <- Formatter.parse_mentions(status),
+ inReplyTo <- get_replied_to_activity(data["in_reply_to_status_id"]),
+ to <- to_for_user_and_mentions(user, mentions, inReplyTo),
+ content_html <- make_content_html(status, mentions, attachments),
+ context <- make_context(inReplyTo),
+ tags <- Formatter.parse_tags(status),
+ object <- make_note_data(user.ap_id, to, context, content_html, attachments, inReplyTo, tags) do
+ res = ActivityPub.create(to, user, context, object)
+ User.update_note_count(user)
+ res