forked from AkkomaGang/akkoma
Add friends status fetching.
This commit is contained in:
parent
569d9bac17
commit
37e443ce6c
6 changed files with 47 additions and 14 deletions
|
@ -1,9 +1,11 @@
|
|||
defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter do
|
||||
use Pleroma.Web.TwitterAPI.Representers.BaseRepresenter
|
||||
alias Pleroma.Web.TwitterAPI.Representers.UserRepresenter
|
||||
alias Pleroma.Activity
|
||||
|
||||
def to_map(activity, %{user: user}) do
|
||||
def to_map(%Activity{} = activity, %{user: user}) do
|
||||
content = get_in(activity.data, ["object", "content"])
|
||||
published = get_in(activity.data, ["object", "published"])
|
||||
%{
|
||||
"id" => activity.id,
|
||||
"user" => UserRepresenter.to_map(user),
|
||||
|
@ -11,7 +13,8 @@ def to_map(activity, %{user: user}) do
|
|||
"statusnet_html" => content,
|
||||
"text" => content,
|
||||
"is_local" => true,
|
||||
"is_post_verb" => true
|
||||
"is_post_verb" => true,
|
||||
"created_at" => published
|
||||
}
|
||||
end
|
||||
end
|
||||
|
|
|
@ -5,6 +5,7 @@ defmodule Pleroma.Web.TwitterAPI.TwitterAPI do
|
|||
alias Pleroma.Web.TwitterAPI.Representers.ActivityRepresenter
|
||||
|
||||
def create_status(user = %User{}, data = %{}) do
|
||||
date = DateTime.utc_now() |> DateTime.to_iso8601
|
||||
activity = %{
|
||||
"type" => "Create",
|
||||
"to" => [
|
||||
|
@ -14,16 +15,26 @@ def create_status(user = %User{}, data = %{}) do
|
|||
"actor" => User.ap_id(user),
|
||||
"object" => %{
|
||||
"type" => "Note",
|
||||
"content" => data["status"]
|
||||
}
|
||||
"content" => data["status"],
|
||||
"published" => date
|
||||
},
|
||||
"published" => date
|
||||
}
|
||||
|
||||
ActivityPub.insert(activity)
|
||||
end
|
||||
|
||||
def fetch_public_statuses(opts \\ %{}) do
|
||||
activities = ActivityPub.fetch_public_activities(opts)
|
||||
def fetch_friend_statuses(user, opts \\ %{}) do
|
||||
ActivityPub.fetch_activities(user.following, opts)
|
||||
|> activities_to_statuses
|
||||
end
|
||||
|
||||
def fetch_public_statuses(opts \\ %{}) do
|
||||
ActivityPub.fetch_public_activities(opts)
|
||||
|> activities_to_statuses
|
||||
end
|
||||
|
||||
defp activities_to_statuses(activities) do
|
||||
Enum.map(activities, fn(activity) ->
|
||||
actor = get_in(activity.data, ["actor"])
|
||||
user = Repo.get_by!(User, ap_id: actor)
|
||||
|
|
|
@ -1,8 +1,8 @@
|
|||
defmodule Pleroma.Builders.UserBuilder do
|
||||
alias Pleroma.{User, Repo}
|
||||
|
||||
def build do
|
||||
%User{
|
||||
def build(data \\ %{}) do
|
||||
user = %User{
|
||||
email: "test@example.org",
|
||||
name: "Test Name",
|
||||
nickname: "testname",
|
||||
|
@ -10,9 +10,10 @@ def build do
|
|||
bio: "A tester.",
|
||||
ap_id: "some id"
|
||||
}
|
||||
Map.merge(user, data)
|
||||
end
|
||||
|
||||
def insert do
|
||||
Repo.insert(build())
|
||||
def insert(data \\ %{}) do
|
||||
Repo.insert(build(data))
|
||||
end
|
||||
end
|
||||
|
|
|
@ -20,7 +20,7 @@ test "inserts a given map into the activity database" do
|
|||
test "retrieve the activities for certain recipients" do
|
||||
{:ok, activity_one} = ActivityBuilder.insert(%{"to" => ["someone"]})
|
||||
{:ok, activity_two} = ActivityBuilder.insert(%{"to" => ["someone_else"]})
|
||||
{:ok, activity_three} = ActivityBuilder.insert(%{"to" => ["noone"]})
|
||||
{:ok, _activity_three} = ActivityBuilder.insert(%{"to" => ["noone"]})
|
||||
|
||||
activities = ActivityPub.fetch_activities(["someone", "someone_else"])
|
||||
assert length(activities) == 2
|
||||
|
|
|
@ -7,6 +7,8 @@ defmodule Pleroma.Web.TwitterAPI.Representers.ActivityRepresenterTest do
|
|||
test "an activity" do
|
||||
{:ok, user} = UserBuilder.insert
|
||||
content = "Some content"
|
||||
date = DateTime.utc_now() |> DateTime.to_iso8601
|
||||
|
||||
activity = %Activity{
|
||||
id: 1,
|
||||
data: %{
|
||||
|
@ -17,9 +19,11 @@ test "an activity" do
|
|||
],
|
||||
"actor" => User.ap_id(user),
|
||||
"object" => %{
|
||||
"published" => date,
|
||||
"type" => "Note",
|
||||
"content" => content
|
||||
}
|
||||
},
|
||||
"published" => date
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -31,7 +35,8 @@ test "an activity" do
|
|||
"attentions" => [],
|
||||
"statusnet_html" => content,
|
||||
"text" => content,
|
||||
"is_post_verb" => true
|
||||
"is_post_verb" => true,
|
||||
"created_at" => date
|
||||
}
|
||||
|
||||
assert ActivityRepresenter.to_map(activity, %{user: user}) == expected_status
|
||||
|
|
|
@ -20,11 +20,24 @@ test "create a status" do
|
|||
assert Enum.member?(get_in(activity.data, ["to"]), "https://www.w3.org/ns/activitystreams#Public")
|
||||
end
|
||||
|
||||
test "fetch public activities" do
|
||||
test "fetch public statuses" do
|
||||
%{ public: activity, user: user } = ActivityBuilder.public_and_non_public
|
||||
statuses = TwitterAPI.fetch_public_statuses()
|
||||
|
||||
assert length(statuses) == 1
|
||||
assert Enum.at(statuses, 0) == ActivityRepresenter.to_map(activity, %{user: user})
|
||||
end
|
||||
|
||||
test "fetch friends' statuses" do
|
||||
ActivityBuilder.public_and_non_public
|
||||
{:ok, activity} = ActivityBuilder.insert(%{"to" => ["someguy/followers"]})
|
||||
{:ok, user} = UserBuilder.insert(%{ap_id: "some other id", following: ["someguy/followers"]})
|
||||
|
||||
statuses = TwitterAPI.fetch_friend_statuses(user)
|
||||
|
||||
activity_user = Repo.get_by(User, ap_id: activity.data["actor"])
|
||||
|
||||
assert length(statuses) == 1
|
||||
assert Enum.at(statuses, 0) == ActivityRepresenter.to_map(activity, %{user: activity_user})
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue