diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/pleroma/web/twitter_api/representers/activity_representer.ex | 19 | 
1 files changed, 16 insertions, 3 deletions
| diff --git a/lib/pleroma/web/twitter_api/representers/activity_representer.ex b/lib/pleroma/web/twitter_api/representers/activity_representer.ex index b0dd85bbb..9e4ffaefe 100644 --- a/lib/pleroma/web/twitter_api/representers/activity_representer.ex +++ b/lib/pleroma/web/twitter_api/representers/activity_representer.ex @@ -3,7 +3,11 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do    alias Pleroma.Web.TwitterAPI.Representers.{UserRepresenter, ObjectRepresenter}    alias Pleroma.Activity +    def to_map(%Activity{data: %{"type" => "Follow"}} = activity, %{user: user} = opts) do +    created_at = get_in(activity.data, ["published"]) +    |> date_to_asctime +      %{        "id" => activity.id,        "user" => UserRepresenter.to_map(user, opts), @@ -12,14 +16,15 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do        "text" => "",        "is_local" => true,        "is_post_verb" => false, -      "created_at" => get_in(activity.data, ["published"]), +      "created_at" => created_at,        "in_reply_to_status_id" => nil,      }    end    def to_map(%Activity{} = activity, %{user: user} = opts) do      content = get_in(activity.data, ["object", "content"]) -    published = get_in(activity.data, ["object", "published"]) +    created_at = get_in(activity.data, ["object", "published"]) +    |> date_to_asctime      mentions = opts[:mentioned] || [] @@ -36,11 +41,19 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do        "text" => HtmlSanitizeEx.strip_tags(content),        "is_local" => true,        "is_post_verb" => true, -      "created_at" => published, +      "created_at" => created_at,        "in_reply_to_status_id" => activity.data["object"]["inReplyToStatusId"],        "statusnet_conversation_id" => activity.data["object"]["statusnetConversationId"],        "attachments" => (activity.data["object"]["attachment"] || []) |> ObjectRepresenter.enum_to_list(opts),        "attentions" => attentions      }    end + +  defp date_to_asctime(date) do +    with {:ok, date, _offset} <- date |> DateTime.from_iso8601 do +      Calendar.Strftime.strftime!(date, "%a %b %d %H:%M:%S %z %Y") +    else e -> +      "" +    end +  end  end | 
