Merging develop into feature/770-add-emoji-tags
Conflict test/web/twitter_api/util_controller_test.exs
This commit is contained in:
		
						commit
						fa8483cb80
					
				
					 18 changed files with 573 additions and 72 deletions
				
			
		|  | @ -32,6 +32,10 @@ defmodule Mix.Tasks.Pleroma.User do | ||||||
| 
 | 
 | ||||||
|       mix pleroma.user rm NICKNAME |       mix pleroma.user rm NICKNAME | ||||||
| 
 | 
 | ||||||
|  |   ## Delete the user's activities. | ||||||
|  | 
 | ||||||
|  |       mix pleroma.user delete_activities NICKNAME | ||||||
|  | 
 | ||||||
|   ## Deactivate or activate the user's account. |   ## Deactivate or activate the user's account. | ||||||
| 
 | 
 | ||||||
|       mix pleroma.user toggle_activated NICKNAME |       mix pleroma.user toggle_activated NICKNAME | ||||||
|  | @ -303,6 +307,18 @@ def run(["invite"]) do | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |   def run(["delete_activities", nickname]) do | ||||||
|  |     Common.start_pleroma() | ||||||
|  | 
 | ||||||
|  |     with %User{local: true} = user <- User.get_by_nickname(nickname) do | ||||||
|  |       User.delete_user_activities(user) | ||||||
|  |       Mix.shell().info("User #{nickname} statuses deleted.") | ||||||
|  |     else | ||||||
|  |       _ -> | ||||||
|  |         Mix.shell().error("No local user #{nickname}") | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   defp set_moderator(user, value) do |   defp set_moderator(user, value) do | ||||||
|     info_cng = User.Info.admin_api_update(user.info, %{is_moderator: value}) |     info_cng = User.Info.admin_api_update(user.info, %{is_moderator: value}) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -3,9 +3,7 @@ | ||||||
| # SPDX-License-Identifier: AGPL-3.0-only | # SPDX-License-Identifier: AGPL-3.0-only | ||||||
| 
 | 
 | ||||||
| defmodule Pleroma.Plugs.UserFetcherPlug do | defmodule Pleroma.Plugs.UserFetcherPlug do | ||||||
|   alias Pleroma.Repo |  | ||||||
|   alias Pleroma.User |   alias Pleroma.User | ||||||
| 
 |  | ||||||
|   import Plug.Conn |   import Plug.Conn | ||||||
| 
 | 
 | ||||||
|   def init(options) do |   def init(options) do | ||||||
|  | @ -14,26 +12,10 @@ def init(options) do | ||||||
| 
 | 
 | ||||||
|   def call(conn, _options) do |   def call(conn, _options) do | ||||||
|     with %{auth_credentials: %{username: username}} <- conn.assigns, |     with %{auth_credentials: %{username: username}} <- conn.assigns, | ||||||
|          {:ok, %User{} = user} <- user_fetcher(username) do |          %User{} = user <- User.get_by_nickname_or_email(username) do | ||||||
|       conn |       assign(conn, :auth_user, user) | ||||||
|       |> assign(:auth_user, user) |  | ||||||
|     else |     else | ||||||
|       _ -> conn |       _ -> conn | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 |  | ||||||
|   defp user_fetcher(username_or_email) do |  | ||||||
|     { |  | ||||||
|       :ok, |  | ||||||
|       cond do |  | ||||||
|         # First, try logging in as if it was a name |  | ||||||
|         user = Repo.get_by(User, %{nickname: username_or_email}) -> |  | ||||||
|           user |  | ||||||
| 
 |  | ||||||
|         # If we get nil, we try using it as an email |  | ||||||
|         user = Repo.get_by(User, %{email: username_or_email}) -> |  | ||||||
|           user |  | ||||||
|       end |  | ||||||
|     } |  | ||||||
|   end |  | ||||||
| end | end | ||||||
|  |  | ||||||
|  | @ -1088,28 +1088,27 @@ def delete(%User{} = user) do | ||||||
|     # Remove all relationships |     # Remove all relationships | ||||||
|     {:ok, followers} = User.get_followers(user) |     {:ok, followers} = User.get_followers(user) | ||||||
| 
 | 
 | ||||||
|     followers |     Enum.each(followers, fn follower -> User.unfollow(follower, user) end) | ||||||
|     |> Enum.each(fn follower -> User.unfollow(follower, user) end) |  | ||||||
| 
 | 
 | ||||||
|     {:ok, friends} = User.get_friends(user) |     {:ok, friends} = User.get_friends(user) | ||||||
| 
 | 
 | ||||||
|     friends |     Enum.each(friends, fn followed -> User.unfollow(user, followed) end) | ||||||
|     |> Enum.each(fn followed -> User.unfollow(user, followed) end) |  | ||||||
| 
 | 
 | ||||||
|     query = |     delete_user_activities(user) | ||||||
|       from(a in Activity, where: a.actor == ^user.ap_id) |   end | ||||||
|  | 
 | ||||||
|  |   def delete_user_activities(%User{ap_id: ap_id} = user) do | ||||||
|  |     Activity | ||||||
|  |     |> where(actor: ^ap_id) | ||||||
|     |> Activity.with_preloaded_object() |     |> Activity.with_preloaded_object() | ||||||
| 
 |     |> Repo.all() | ||||||
|     Repo.all(query) |     |> Enum.each(fn | ||||||
|     |> Enum.each(fn activity -> |       %{data: %{"type" => "Create"}} = activity -> | ||||||
|       case activity.data["type"] do |         activity |> Object.normalize() |> ActivityPub.delete() | ||||||
|         "Create" -> |  | ||||||
|           ActivityPub.delete(Object.normalize(activity)) |  | ||||||
| 
 | 
 | ||||||
|       # TODO: Do something with likes, follows, repeats. |       # TODO: Do something with likes, follows, repeats. | ||||||
|       _ -> |       _ -> | ||||||
|         "Doing nothing" |         "Doing nothing" | ||||||
|       end |  | ||||||
|     end) |     end) | ||||||
| 
 | 
 | ||||||
|     {:ok, user} |     {:ok, user} | ||||||
|  |  | ||||||
|  | @ -756,7 +756,7 @@ def follow(%{assigns: %{user: follower}} = conn, %{"id" => id}) do | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   def follow(%{assigns: %{user: follower}} = conn, %{"uri" => uri}) do |   def follow(%{assigns: %{user: follower}} = conn, %{"uri" => uri}) do | ||||||
|     with %User{} = followed <- Repo.get_by(User, nickname: uri), |     with %User{} = followed <- User.get_by_nickname(uri), | ||||||
|          {:ok, follower, followed, _} <- CommonAPI.follow(follower, followed) do |          {:ok, follower, followed, _} <- CommonAPI.follow(follower, followed) do | ||||||
|       conn |       conn | ||||||
|       |> put_view(AccountView) |       |> put_view(AccountView) | ||||||
|  |  | ||||||
|  | @ -8,6 +8,7 @@ defmodule Pleroma.Web.TwitterAPI.UtilController do | ||||||
|   require Logger |   require Logger | ||||||
| 
 | 
 | ||||||
|   alias Comeonin.Pbkdf2 |   alias Comeonin.Pbkdf2 | ||||||
|  |   alias Pleroma.Activity | ||||||
|   alias Pleroma.Emoji |   alias Pleroma.Emoji | ||||||
|   alias Pleroma.Notification |   alias Pleroma.Notification | ||||||
|   alias Pleroma.PasswordResetToken |   alias Pleroma.PasswordResetToken | ||||||
|  | @ -73,6 +74,11 @@ def remote_subscribe(conn, %{"user" => %{"nickname" => nick, "profile" => profil | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   def remote_follow(%{assigns: %{user: user}} = conn, %{"acct" => acct}) do |   def remote_follow(%{assigns: %{user: user}} = conn, %{"acct" => acct}) do | ||||||
|  |     if is_status?(acct) do | ||||||
|  |       {:ok, object} = ActivityPub.fetch_object_from_id(acct) | ||||||
|  |       %Activity{id: activity_id} = Activity.get_create_by_object_ap_id(object.data["id"]) | ||||||
|  |       redirect(conn, to: "/notice/#{activity_id}") | ||||||
|  |     else | ||||||
|       {err, followee} = OStatus.find_or_make_user(acct) |       {err, followee} = OStatus.find_or_make_user(acct) | ||||||
|       avatar = User.avatar_url(followee) |       avatar = User.avatar_url(followee) | ||||||
|       name = followee.nickname |       name = followee.nickname | ||||||
|  | @ -92,6 +98,17 @@ def remote_follow(%{assigns: %{user: user}} = conn, %{"acct" => acct}) do | ||||||
|         }) |         }) | ||||||
|       end |       end | ||||||
|     end |     end | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|  |   defp is_status?(acct) do | ||||||
|  |     case ActivityPub.fetch_and_contain_remote_object_from_id(acct) do | ||||||
|  |       {:ok, %{"type" => type}} when type in ["Article", "Note", "Video", "Page", "Question"] -> | ||||||
|  |         true | ||||||
|  | 
 | ||||||
|  |       _ -> | ||||||
|  |         false | ||||||
|  |     end | ||||||
|  |   end | ||||||
| 
 | 
 | ||||||
|   def do_remote_follow(conn, %{ |   def do_remote_follow(conn, %{ | ||||||
|         "authorization" => %{"name" => username, "password" => password, "id" => id} |         "authorization" => %{"name" => username, "password" => password, "id" => id} | ||||||
|  |  | ||||||
|  | @ -227,12 +227,9 @@ def get_user(user \\ nil, params) do | ||||||
|         end |         end | ||||||
| 
 | 
 | ||||||
|       %{"screen_name" => nickname} -> |       %{"screen_name" => nickname} -> | ||||||
|         case target = Repo.get_by(User, nickname: nickname) do |         case User.get_by_nickname(nickname) do | ||||||
|           nil -> |           nil -> {:error, "No user with such screen_name"} | ||||||
|             {:error, "No user with such screen_name"} |           target -> {:ok, target} | ||||||
| 
 |  | ||||||
|           _ -> |  | ||||||
|             {:ok, target} |  | ||||||
|         end |         end | ||||||
| 
 | 
 | ||||||
|       _ -> |       _ -> | ||||||
|  |  | ||||||
							
								
								
									
										306
									
								
								test/fixtures/httpoison_mock/emelie.atom
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										306
									
								
								test/fixtures/httpoison_mock/emelie.atom
									
									
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,306 @@ | ||||||
|  | <?xml version="1.0"?> | ||||||
|  | <feed xmlns="http://www.w3.org/2005/Atom" xmlns:thr="http://purl.org/syndication/thread/1.0" xmlns:activity="http://activitystrea.ms/spec/1.0/" xmlns:poco="http://portablecontacts.net/spec/1.0" xmlns:media="http://purl.org/syndication/atommedia" xmlns:ostatus="http://ostatus.org/schema/1.0" xmlns:mastodon="http://mastodon.social/schema/1.0"> | ||||||
|  |     <id>https://mastodon.social/users/emelie.atom</id> | ||||||
|  |     <title>emelie 🎨</title> | ||||||
|  |     <subtitle>23 / #Sweden / #Artist / #Equestrian / #GameDev | ||||||
|  | 
 | ||||||
|  | If I ain't spending time with my pets, I'm probably drawing. 🐴 🐱 🐰</subtitle> | ||||||
|  |     <updated>2019-02-04T20:22:19Z</updated> | ||||||
|  |     <logo>https://files.mastodon.social/accounts/avatars/000/015/657/original/e7163f98280da1a4.png</logo> | ||||||
|  |     <author> | ||||||
|  |         <id>https://mastodon.social/users/emelie</id> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/person</activity:object-type> | ||||||
|  |         <uri>https://mastodon.social/users/emelie</uri> | ||||||
|  |         <name>emelie</name> | ||||||
|  |         <email>emelie@mastodon.social</email> | ||||||
|  |         <summary type="html"><p>23 / <a href="https://mastodon.social/tags/sweden" class="mention hashtag" rel="tag">#<span>Sweden</span></a> / <a href="https://mastodon.social/tags/artist" class="mention hashtag" rel="tag">#<span>Artist</span></a> / <a href="https://mastodon.social/tags/equestrian" class="mention hashtag" rel="tag">#<span>Equestrian</span></a> / <a href="https://mastodon.social/tags/gamedev" class="mention hashtag" rel="tag">#<span>GameDev</span></a></p><p>If I ain&apos;t spending time with my pets, I&apos;m probably drawing. 🐴 🐱 🐰</p></summary> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie"/> | ||||||
|  |         <link rel="avatar" type="image/png" media:width="120" media:height="120" href="https://files.mastodon.social/accounts/avatars/000/015/657/original/e7163f98280da1a4.png"/> | ||||||
|  |         <link rel="header" type="image/png" media:width="700" media:height="335" href="https://files.mastodon.social/accounts/headers/000/015/657/original/847f331f3dd9e38b.png"/> | ||||||
|  |         <poco:preferredUsername>emelie</poco:preferredUsername> | ||||||
|  |         <poco:displayName>emelie 🎨</poco:displayName> | ||||||
|  |         <poco:note>23 / #Sweden / #Artist / #Equestrian / #GameDev | ||||||
|  | 
 | ||||||
|  | If I ain't spending time with my pets, I'm probably drawing. 🐴 🐱 🐰</poco:note> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |     </author> | ||||||
|  |     <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie"/> | ||||||
|  |     <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie.atom"/> | ||||||
|  |     <link rel="hub" href="https://mastodon.social/api/push"/> | ||||||
|  |     <link rel="salmon" href="https://mastodon.social/api/salmon/15657"/> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101850331907006641</id> | ||||||
|  |         <published>2019-04-01T09:58:50Z</published> | ||||||
|  |         <updated>2019-04-01T09:58:50Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101850331907006641"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>Me: I&apos;m going to make this vital change to my world building in the morning, no way I&apos;ll forget this, it&apos;s too big of a deal<br />Also me: forgets</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101850331907006641"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17854598.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-04-01:objectId=94383214:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101849626603073336</id> | ||||||
|  |         <published>2019-04-01T06:59:28Z</published> | ||||||
|  |         <updated>2019-04-01T06:59:28Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/comment</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101849626603073336"/> | ||||||
|  |         <content type="html" xml:lang="sv"><p><span class="h-card"><a href="https://mastodon.social/@Fergant" class="u-url mention">@<span>Fergant</span></a></span> Dom är i stort sett religiös skrift vid det här laget 👏👏</p><p>har dock bara läst svenska översättningen, kanske är dags att jag läser dom på engelska</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/person" href="https://mastodon.social/users/Fergant"/> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101849626603073336"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17852590.atom"/> | ||||||
|  |         <thr:in-reply-to ref="https://mastodon.social/users/Fergant/statuses/101849606513357387" href="https://mastodon.social/@Fergant/101849606513357387"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-04-01:objectId=94362529:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101849580030237068</id> | ||||||
|  |         <published>2019-04-01T06:47:37Z</published> | ||||||
|  |         <updated>2019-04-01T06:47:37Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101849580030237068"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>What&apos;s you people&apos;s favourite fantasy books? Give me some hot tips 🌞</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101849580030237068"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17852464.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-04-01:objectId=94362529:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101849550599949363</id> | ||||||
|  |         <published>2019-04-01T06:40:08Z</published> | ||||||
|  |         <updated>2019-04-01T06:40:08Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101849550599949363"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>Stick them legs out 💃 <a href="https://mastodon.social/tags/mastocats" class="mention hashtag" rel="tag">#<span>mastocats</span></a></p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <category term="mastocats"/> | ||||||
|  |         <link rel="enclosure" type="image/jpeg" length="516384" href="https://files.mastodon.social/media_attachments/files/013/051/707/original/125a310abe9a34aa.jpeg"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101849550599949363"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17852407.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-04-01:objectId=94361580:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101849191533152720</id> | ||||||
|  |         <published>2019-04-01T05:08:49Z</published> | ||||||
|  |         <updated>2019-04-01T05:08:49Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101849191533152720"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>long 🐱 <a href="https://mastodon.social/tags/mastocats" class="mention hashtag" rel="tag">#<span>mastocats</span></a></p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <category term="mastocats"/> | ||||||
|  |         <link rel="enclosure" type="image/jpeg" length="305208" href="https://files.mastodon.social/media_attachments/files/013/049/940/original/f2dbbfe7de3a17d2.jpeg"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101849191533152720"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17851663.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-04-01:objectId=94351141:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101849165031453009</id> | ||||||
|  |         <published>2019-04-01T05:02:05Z</published> | ||||||
|  |         <updated>2019-04-01T05:02:05Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101849165031453009"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>You gotta take whatever bellyrubbing opportunity you can get before she changes her mind 🦁 <a href="https://mastodon.social/tags/mastocats" class="mention hashtag" rel="tag">#<span>mastocats</span></a></p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <category term="mastocats"/> | ||||||
|  |         <link rel="enclosure" type="video/mp4" length="9838915" href="https://files.mastodon.social/media_attachments/files/013/049/816/original/e7831178a5e0d6d4.mp4"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101849165031453009"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17851558.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-04-01:objectId=94350309:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101846512530748693</id> | ||||||
|  |         <published>2019-03-31T17:47:31Z</published> | ||||||
|  |         <updated>2019-03-31T17:47:31Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101846512530748693"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>Hello look at this boy having a decent haircut for once <a href="https://mastodon.social/tags/mastohorses" class="mention hashtag" rel="tag">#<span>mastohorses</span></a> <a href="https://mastodon.social/tags/equestrian" class="mention hashtag" rel="tag">#<span>equestrian</span></a></p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <category term="equestrian"/> | ||||||
|  |         <category term="mastohorses"/> | ||||||
|  |         <link rel="enclosure" type="image/jpeg" length="461632" href="https://files.mastodon.social/media_attachments/files/013/033/387/original/301e8ab668cd61d2.jpeg"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101846512530748693"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17842424.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-31:objectId=94256415:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101846181093805500</id> | ||||||
|  |         <published>2019-03-31T16:23:14Z</published> | ||||||
|  |         <updated>2019-03-31T16:23:14Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101846181093805500"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>Sorry did I disturb the who-is-the-longest-cat competition ?  <a href="https://mastodon.social/tags/mastocats" class="mention hashtag" rel="tag">#<span>mastocats</span></a></p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <category term="mastocats"/> | ||||||
|  |         <link rel="enclosure" type="image/jpeg" length="211384" href="https://files.mastodon.social/media_attachments/files/013/030/725/original/5b4886730cbbd25c.jpeg"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101846181093805500"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17841108.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-31:objectId=94245239:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101845897513133849</id> | ||||||
|  |         <published>2019-03-31T15:11:07Z</published> | ||||||
|  |         <updated>2019-03-31T15:11:07Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101845897513133849"/> | ||||||
|  |         <summary xml:lang="en">more earthsea ramblings</summary> | ||||||
|  |         <content type="html" xml:lang="en"><p>I&apos;m re-watching Tales from Earthsea for the first time since I read the books, and that Therru doesn&apos;t squash Cob like a spider, as Orm Embar did is a wasted opportunity tbh</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101845897513133849"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17840088.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-31:objectId=94232455:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101841219051533307</id> | ||||||
|  |         <published>2019-03-30T19:21:19Z</published> | ||||||
|  |         <updated>2019-03-30T19:21:19Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101841219051533307"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>I gave my cats some mackerel and they ate it all in 0.3 seconds, and now they won&apos;t stop meowing for more, and I&apos;m tired plz shut up</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101841219051533307"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17826587.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-30:objectId=94075000:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101839949762341381</id> | ||||||
|  |         <published>2019-03-30T13:58:31Z</published> | ||||||
|  |         <updated>2019-03-30T13:58:31Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/comment</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101839949762341381"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>yet I&apos;m  confused about this american dude with a gun, like the heck r ya doin in mah ghibli</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101839949762341381"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17821757.atom"/> | ||||||
|  |         <thr:in-reply-to ref="https://mastodon.social/users/emelie/statuses/101839928677863590" href="https://mastodon.social/@emelie/101839928677863590"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-30:objectId=94026360:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101839928677863590</id> | ||||||
|  |         <published>2019-03-30T13:53:09Z</published> | ||||||
|  |         <updated>2019-03-30T13:53:09Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101839928677863590"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>2 hours into Ni no Kuni 2 and I&apos;ve already sold my soul to this game</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101839928677863590"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17821713.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-30:objectId=94026360:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101836329521599438</id> | ||||||
|  |         <published>2019-03-29T22:37:51Z</published> | ||||||
|  |         <updated>2019-03-29T22:37:51Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101836329521599438"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>Pippi Longstocking the original one-punch /man</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101836329521599438"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17811608.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-29:objectId=93907854:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101835905282948341</id> | ||||||
|  |         <published>2019-03-29T20:49:57Z</published> | ||||||
|  |         <updated>2019-03-29T20:49:57Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101835905282948341"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>I&apos;ve had so much wine I thought I had a 3rd brother</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101835905282948341"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17809862.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-29:objectId=93892966:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101835878059204660</id> | ||||||
|  |         <published>2019-03-29T20:43:02Z</published> | ||||||
|  |         <updated>2019-03-29T20:43:02Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/note</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101835878059204660"/> | ||||||
|  |         <content type="html" xml:lang="en"><p>ååååhhh booi</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101835878059204660"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17809734.atom"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-29:objectId=93892010:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101835848050598939</id> | ||||||
|  |         <published>2019-03-29T20:35:24Z</published> | ||||||
|  |         <updated>2019-03-29T20:35:24Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/comment</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101835848050598939"/> | ||||||
|  |         <content type="html" xml:lang="en"><p><span class="h-card"><a href="https://thraeryn.net/@thraeryn" class="u-url mention">@<span>thraeryn</span></a></span> if I spent 1 hour and a half watching this monstrosity, I need to</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/person" href="https://thraeryn.net/users/thraeryn"/> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101835848050598939"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17809591.atom"/> | ||||||
|  |         <thr:in-reply-to ref="https://thraeryn.net/users/thraeryn/statuses/101835839202826007" href="https://thraeryn.net/@thraeryn/101835839202826007"/> | ||||||
|  |         <ostatus:conversation ref="tag:mastodon.social,2019-03-29:objectId=93888827:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  |     <entry> | ||||||
|  |         <id>https://mastodon.social/users/emelie/statuses/101835823138262290</id> | ||||||
|  |         <published>2019-03-29T20:29:04Z</published> | ||||||
|  |         <updated>2019-03-29T20:29:04Z</updated> | ||||||
|  |         <title>New status by emelie</title> | ||||||
|  |         <activity:object-type>http://activitystrea.ms/schema/1.0/comment</activity:object-type> | ||||||
|  |         <activity:verb>http://activitystrea.ms/schema/1.0/post</activity:verb> | ||||||
|  |         <link rel="alternate" type="application/activity+json" href="https://mastodon.social/users/emelie/statuses/101835823138262290"/> | ||||||
|  |         <summary xml:lang="en">medical, fluids mention</summary> | ||||||
|  |         <content type="html" xml:lang="en"><p><span class="h-card"><a href="https://icosahedron.website/@Trev" class="u-url mention">@<span>Trev</span></a></span> *hugs* ✨</p></content> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/person" href="https://icosahedron.website/users/Trev"/> | ||||||
|  |         <link rel="mentioned" ostatus:object-type="http://activitystrea.ms/schema/1.0/collection" href="http://activityschema.org/collection/public"/> | ||||||
|  |         <mastodon:scope>public</mastodon:scope> | ||||||
|  |         <link rel="alternate" type="text/html" href="https://mastodon.social/@emelie/101835823138262290"/> | ||||||
|  |         <link rel="self" type="application/atom+xml" href="https://mastodon.social/users/emelie/updates/17809468.atom"/> | ||||||
|  |         <thr:in-reply-to ref="https://icosahedron.website/users/Trev/statuses/101835812250051801" href="https://icosahedron.website/@Trev/101835812250051801"/> | ||||||
|  |         <ostatus:conversation ref="tag:icosahedron.website,2019-03-29:objectId=12220882:objectType=Conversation"/> | ||||||
|  |     </entry> | ||||||
|  | </feed> | ||||||
							
								
								
									
										64
									
								
								test/fixtures/httpoison_mock/status.emelie.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								test/fixtures/httpoison_mock/status.emelie.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,64 @@ | ||||||
|  | { | ||||||
|  |     "@context": [ | ||||||
|  |         "https://www.w3.org/ns/activitystreams", | ||||||
|  |         { | ||||||
|  |             "ostatus": "http://ostatus.org#", | ||||||
|  |             "atomUri": "ostatus:atomUri", | ||||||
|  |             "inReplyToAtomUri": "ostatus:inReplyToAtomUri", | ||||||
|  |             "conversation": "ostatus:conversation", | ||||||
|  |             "sensitive": "as:sensitive", | ||||||
|  |             "Hashtag": "as:Hashtag", | ||||||
|  |             "toot": "http://joinmastodon.org/ns#", | ||||||
|  |             "Emoji": "toot:Emoji", | ||||||
|  |             "focalPoint": { | ||||||
|  |                 "@container": "@list", | ||||||
|  |                 "@id": "toot:focalPoint" | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "id": "https://mastodon.social/users/emelie/statuses/101849165031453009", | ||||||
|  |     "type": "Note", | ||||||
|  |     "summary": null, | ||||||
|  |     "inReplyTo": null, | ||||||
|  |     "published": "2019-04-01T05:02:05Z", | ||||||
|  |     "url": "https://mastodon.social/@emelie/101849165031453009", | ||||||
|  |     "attributedTo": "https://mastodon.social/users/emelie", | ||||||
|  |     "to": [ | ||||||
|  |         "https://www.w3.org/ns/activitystreams#Public" | ||||||
|  |     ], | ||||||
|  |     "cc": [ | ||||||
|  |         "https://mastodon.social/users/emelie/followers" | ||||||
|  |     ], | ||||||
|  |     "sensitive": false, | ||||||
|  |     "atomUri": "https://mastodon.social/users/emelie/statuses/101849165031453009", | ||||||
|  |     "inReplyToAtomUri": null, | ||||||
|  |     "conversation": "tag:mastodon.social,2019-04-01:objectId=94350309:objectType=Conversation", | ||||||
|  |     "content": "<p>You gotta take whatever bellyrubbing opportunity you can get before she changes her mind 🦁 <a href=\"https://mastodon.social/tags/mastocats\" class=\"mention hashtag\" rel=\"tag\">#<span>mastocats</span></a></p>", | ||||||
|  |     "contentMap": { | ||||||
|  |         "en": "<p>You gotta take whatever bellyrubbing opportunity you can get before she changes her mind 🦁 <a href=\"https://mastodon.social/tags/mastocats\" class=\"mention hashtag\" rel=\"tag\">#<span>mastocats</span></a></p>" | ||||||
|  |     }, | ||||||
|  |     "attachment": [ | ||||||
|  |         { | ||||||
|  |             "type": "Document", | ||||||
|  |             "mediaType": "video/mp4", | ||||||
|  |             "url": "https://files.mastodon.social/media_attachments/files/013/049/816/original/e7831178a5e0d6d4.mp4", | ||||||
|  |             "name": null | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "tag": [ | ||||||
|  |         { | ||||||
|  |             "type": "Hashtag", | ||||||
|  |             "href": "https://mastodon.social/tags/mastocats", | ||||||
|  |             "name": "#mastocats" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "replies": { | ||||||
|  |         "id": "https://mastodon.social/users/emelie/statuses/101849165031453009/replies", | ||||||
|  |         "type": "Collection", | ||||||
|  |         "first": { | ||||||
|  |             "type": "CollectionPage", | ||||||
|  |             "partOf": "https://mastodon.social/users/emelie/statuses/101849165031453009/replies", | ||||||
|  |             "items": [] | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										36
									
								
								test/fixtures/httpoison_mock/webfinger_emelie.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								test/fixtures/httpoison_mock/webfinger_emelie.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,36 @@ | ||||||
|  | { | ||||||
|  |     "aliases": [ | ||||||
|  |         "https://mastodon.social/@emelie", | ||||||
|  |         "https://mastodon.social/users/emelie" | ||||||
|  |     ], | ||||||
|  |     "links": [ | ||||||
|  |         { | ||||||
|  |             "href": "https://mastodon.social/@emelie", | ||||||
|  |             "rel": "http://webfinger.net/rel/profile-page", | ||||||
|  |             "type": "text/html" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "href": "https://mastodon.social/users/emelie.atom", | ||||||
|  |             "rel": "http://schemas.google.com/g/2010#updates-from", | ||||||
|  |             "type": "application/atom+xml" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "href": "https://mastodon.social/users/emelie", | ||||||
|  |             "rel": "self", | ||||||
|  |             "type": "application/activity+json" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "href": "https://mastodon.social/api/salmon/15657", | ||||||
|  |             "rel": "salmon" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "href": "data:application/magic-public-key,RSA.u3CWs1oAJPE3ZJ9sj6Ut_Mu-mTE7MOijsQc8_6c73XVVuhIEomiozJIH7l8a7S1n5SYL4UuiwcubSOi7u1bbGpYnp5TYhN-Cxvq_P80V4_ncNIPSQzS49it7nSLeG5pA21lGPDA44huquES1un6p9gSmbTwngVX9oe4MYuUeh0Z7vijjU13Llz1cRq_ZgPQPgfz-2NJf-VeXnvyDZDYxZPVBBlrMl3VoGbu0M5L8SjY35559KCZ3woIvqRolcoHXfgvJMdPcJgSZVYxlCw3dA95q9jQcn6s87CPSUs7bmYEQCrDVn5m5NER5TzwBmP4cgJl9AaDVWQtRd4jFZNTxlQ==.AQAB", | ||||||
|  |             "rel": "magic-public-key" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "rel": "http://ostatus.org/schema/1.0/subscribe", | ||||||
|  |             "template": "https://mastodon.social/authorize_interaction?uri={uri}" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "subject": "acct:emelie@mastodon.social" | ||||||
|  | } | ||||||
|  | @ -36,6 +36,43 @@ def get("https://osada.macgirvin.com/channel/mike", _, _, _) do | ||||||
|      }} |      }} | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |   def get("https://mastodon.social/users/emelie/statuses/101849165031453009", _, _, _) do | ||||||
|  |     {:ok, | ||||||
|  |      %Tesla.Env{ | ||||||
|  |        status: 200, | ||||||
|  |        body: File.read!("test/fixtures/httpoison_mock/status.emelie.json") | ||||||
|  |      }} | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|  |   def get("https://mastodon.social/users/emelie", _, _, _) do | ||||||
|  |     {:ok, | ||||||
|  |      %Tesla.Env{ | ||||||
|  |        status: 200, | ||||||
|  |        body: File.read!("test/fixtures/httpoison_mock/emelie.json") | ||||||
|  |      }} | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|  |   def get( | ||||||
|  |         "https://mastodon.social/.well-known/webfinger?resource=https://mastodon.social/users/emelie", | ||||||
|  |         _, | ||||||
|  |         _, | ||||||
|  |         _ | ||||||
|  |       ) do | ||||||
|  |     {:ok, | ||||||
|  |      %Tesla.Env{ | ||||||
|  |        status: 200, | ||||||
|  |        body: File.read!("test/fixtures/httpoison_mock/webfinger_emelie.json") | ||||||
|  |      }} | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|  |   def get("https://mastodon.social/users/emelie.atom", _, _, _) do | ||||||
|  |     {:ok, | ||||||
|  |      %Tesla.Env{ | ||||||
|  |        status: 200, | ||||||
|  |        body: File.read!("test/fixtures/httpoison_mock/emelie.atom") | ||||||
|  |      }} | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   def get( |   def get( | ||||||
|         "https://osada.macgirvin.com/.well-known/webfinger?resource=acct:mike@osada.macgirvin.com", |         "https://osada.macgirvin.com/.well-known/webfinger?resource=acct:mike@osada.macgirvin.com", | ||||||
|         _, |         _, | ||||||
|  |  | ||||||
|  | @ -248,4 +248,14 @@ test "invite token is generated" do | ||||||
|       assert message =~ "Generated" |       assert message =~ "Generated" | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  | 
 | ||||||
|  |   describe "running delete_activities" do | ||||||
|  |     test "activities are deleted" do | ||||||
|  |       %{nickname: nickname} = insert(:user) | ||||||
|  | 
 | ||||||
|  |       assert :ok == Mix.Tasks.Pleroma.User.run(["delete_activities", nickname]) | ||||||
|  |       assert_received {:mix_shell, :info, [message]} | ||||||
|  |       assert message == "User #{nickname} statuses deleted." | ||||||
|  |     end | ||||||
|  |   end | ||||||
| end | end | ||||||
|  |  | ||||||
|  | @ -799,6 +799,16 @@ test ".deactivate can de-activate then re-activate a user" do | ||||||
|     assert false == user.info.deactivated |     assert false == user.info.deactivated | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |   test ".delete_user_activities deletes all create activities" do | ||||||
|  |     user = insert(:user) | ||||||
|  | 
 | ||||||
|  |     {:ok, activity} = CommonAPI.post(user, %{"status" => "2hu"}) | ||||||
|  |     {:ok, _} = User.delete_user_activities(user) | ||||||
|  | 
 | ||||||
|  |     # TODO: Remove favorites, repeats, delete activities. | ||||||
|  |     refute Activity.get_by_id(activity.id) | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   test ".delete deactivates a user, all follow relationships and all create activities" do |   test ".delete deactivates a user, all follow relationships and all create activities" do | ||||||
|     user = insert(:user) |     user = insert(:user) | ||||||
|     followed = insert(:user) |     followed = insert(:user) | ||||||
|  |  | ||||||
|  | @ -638,8 +638,8 @@ test "works with base64 encoded images" do | ||||||
|   describe "fetch the latest Follow" do |   describe "fetch the latest Follow" do | ||||||
|     test "fetches the latest Follow activity" do |     test "fetches the latest Follow activity" do | ||||||
|       %Activity{data: %{"type" => "Follow"}} = activity = insert(:follow_activity) |       %Activity{data: %{"type" => "Follow"}} = activity = insert(:follow_activity) | ||||||
|       follower = Repo.get_by(User, ap_id: activity.data["actor"]) |       follower = User.get_by_ap_id(activity.data["actor"]) | ||||||
|       followed = Repo.get_by(User, ap_id: activity.data["object"]) |       followed = User.get_by_ap_id(activity.data["object"]) | ||||||
| 
 | 
 | ||||||
|       assert activity == Utils.fetch_latest_follow(follower, followed) |       assert activity == Utils.fetch_latest_follow(follower, followed) | ||||||
|     end |     end | ||||||
|  |  | ||||||
|  | @ -175,7 +175,7 @@ test "contains mentions" do | ||||||
| 
 | 
 | ||||||
|     status = StatusView.render("status.json", %{activity: activity}) |     status = StatusView.render("status.json", %{activity: activity}) | ||||||
| 
 | 
 | ||||||
|     actor = Repo.get_by(User, ap_id: activity.actor) |     actor = User.get_by_ap_id(activity.actor) | ||||||
| 
 | 
 | ||||||
|     assert status.mentions == |     assert status.mentions == | ||||||
|              Enum.map([user, actor], fn u -> AccountView.render("mention.json", %{user: u}) end) |              Enum.map([user, actor], fn u -> AccountView.render("mention.json", %{user: u}) end) | ||||||
|  |  | ||||||
|  | @ -99,7 +99,7 @@ test "it pushes an activity to remote accounts it's addressed to" do | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     {:ok, activity} = Repo.insert(%Activity{data: activity_data, recipients: activity_data["to"]}) |     {:ok, activity} = Repo.insert(%Activity{data: activity_data, recipients: activity_data["to"]}) | ||||||
|     user = Repo.get_by(User, ap_id: activity.data["actor"]) |     user = User.get_by_ap_id(activity.data["actor"]) | ||||||
|     {:ok, user} = Pleroma.Web.WebFinger.ensure_keys_present(user) |     {:ok, user} = Pleroma.Web.WebFinger.ensure_keys_present(user) | ||||||
| 
 | 
 | ||||||
|     poster = fn url, _data, _headers -> |     poster = fn url, _data, _headers -> | ||||||
|  |  | ||||||
|  | @ -955,7 +955,7 @@ test "with credentials", %{conn: conn, user: current_user} do | ||||||
|         |> post(request_path) |         |> post(request_path) | ||||||
| 
 | 
 | ||||||
|       activity = Activity.get_by_id(note_activity.id) |       activity = Activity.get_by_id(note_activity.id) | ||||||
|       activity_user = Repo.get_by(User, ap_id: note_activity.data["actor"]) |       activity_user = User.get_by_ap_id(note_activity.data["actor"]) | ||||||
| 
 | 
 | ||||||
|       assert json_response(response, 200) == |       assert json_response(response, 200) == | ||||||
|                ActivityView.render("activity.json", %{ |                ActivityView.render("activity.json", %{ | ||||||
|  | @ -993,7 +993,7 @@ test "with credentials", %{conn: conn, user: current_user} do | ||||||
|         |> post(request_path) |         |> post(request_path) | ||||||
| 
 | 
 | ||||||
|       activity = Activity.get_by_id(note_activity.id) |       activity = Activity.get_by_id(note_activity.id) | ||||||
|       activity_user = Repo.get_by(User, ap_id: note_activity.data["actor"]) |       activity_user = User.get_by_ap_id(note_activity.data["actor"]) | ||||||
| 
 | 
 | ||||||
|       assert json_response(response, 200) == |       assert json_response(response, 200) == | ||||||
|                ActivityView.render("activity.json", %{ |                ActivityView.render("activity.json", %{ | ||||||
|  | @ -1021,7 +1021,7 @@ test "it creates a new user", %{conn: conn} do | ||||||
| 
 | 
 | ||||||
|       user = json_response(conn, 200) |       user = json_response(conn, 200) | ||||||
| 
 | 
 | ||||||
|       fetched_user = Repo.get_by(User, nickname: "lain") |       fetched_user = User.get_by_nickname("lain") | ||||||
|       assert user == UserView.render("show.json", %{user: fetched_user}) |       assert user == UserView.render("show.json", %{user: fetched_user}) | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -275,7 +275,7 @@ test "it registers a new user and returns the user." do | ||||||
| 
 | 
 | ||||||
|     {:ok, user} = TwitterAPI.register_user(data) |     {:ok, user} = TwitterAPI.register_user(data) | ||||||
| 
 | 
 | ||||||
|     fetched_user = Repo.get_by(User, nickname: "lain") |     fetched_user = User.get_by_nickname("lain") | ||||||
| 
 | 
 | ||||||
|     assert UserView.render("show.json", %{user: user}) == |     assert UserView.render("show.json", %{user: user}) == | ||||||
|              UserView.render("show.json", %{user: fetched_user}) |              UserView.render("show.json", %{user: fetched_user}) | ||||||
|  | @ -293,7 +293,7 @@ test "it registers a new user with empty string in bio and returns the user." do | ||||||
| 
 | 
 | ||||||
|     {:ok, user} = TwitterAPI.register_user(data) |     {:ok, user} = TwitterAPI.register_user(data) | ||||||
| 
 | 
 | ||||||
|     fetched_user = Repo.get_by(User, nickname: "lain") |     fetched_user = User.get_by_nickname("lain") | ||||||
| 
 | 
 | ||||||
|     assert UserView.render("show.json", %{user: user}) == |     assert UserView.render("show.json", %{user: user}) == | ||||||
|              UserView.render("show.json", %{user: fetched_user}) |              UserView.render("show.json", %{user: fetched_user}) | ||||||
|  | @ -369,7 +369,7 @@ test "it registers a new user via invite token and returns the user." do | ||||||
| 
 | 
 | ||||||
|     {:ok, user} = TwitterAPI.register_user(data) |     {:ok, user} = TwitterAPI.register_user(data) | ||||||
| 
 | 
 | ||||||
|     fetched_user = Repo.get_by(User, nickname: "vinny") |     fetched_user = User.get_by_nickname("vinny") | ||||||
|     token = Repo.get_by(UserInviteToken, token: token.token) |     token = Repo.get_by(UserInviteToken, token: token.token) | ||||||
| 
 | 
 | ||||||
|     assert token.used == true |     assert token.used == true | ||||||
|  | @ -393,7 +393,7 @@ test "it returns an error if invalid token submitted" do | ||||||
|     {:error, msg} = TwitterAPI.register_user(data) |     {:error, msg} = TwitterAPI.register_user(data) | ||||||
| 
 | 
 | ||||||
|     assert msg == "Invalid token" |     assert msg == "Invalid token" | ||||||
|     refute Repo.get_by(User, nickname: "GrimReaper") |     refute User.get_by_nickname("GrimReaper") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   @moduletag skip: "needs 'registrations_open: false' in config" |   @moduletag skip: "needs 'registrations_open: false' in config" | ||||||
|  | @ -414,7 +414,7 @@ test "it returns an error if expired token submitted" do | ||||||
|     {:error, msg} = TwitterAPI.register_user(data) |     {:error, msg} = TwitterAPI.register_user(data) | ||||||
| 
 | 
 | ||||||
|     assert msg == "Expired token" |     assert msg == "Expired token" | ||||||
|     refute Repo.get_by(User, nickname: "GrimReaper") |     refute User.get_by_nickname("GrimReaper") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   test "it returns the error on registration problems" do |   test "it returns the error on registration problems" do | ||||||
|  | @ -429,7 +429,7 @@ test "it returns the error on registration problems" do | ||||||
|     {:error, error_object} = TwitterAPI.register_user(data) |     {:error, error_object} = TwitterAPI.register_user(data) | ||||||
| 
 | 
 | ||||||
|     assert is_binary(error_object[:error]) |     assert is_binary(error_object[:error]) | ||||||
|     refute Repo.get_by(User, nickname: "lain") |     refute User.get_by_nickname("lain") | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   test "it assigns an integer conversation_id" do |   test "it assigns an integer conversation_id" do | ||||||
|  |  | ||||||
|  | @ -6,6 +6,11 @@ defmodule Pleroma.Web.TwitterAPI.UtilControllerTest do | ||||||
|   alias Pleroma.Web.CommonAPI |   alias Pleroma.Web.CommonAPI | ||||||
|   import Pleroma.Factory |   import Pleroma.Factory | ||||||
| 
 | 
 | ||||||
|  |   setup do | ||||||
|  |     Tesla.Mock.mock(fn env -> apply(HttpRequestMock, :request, [env]) end) | ||||||
|  |     :ok | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   describe "POST /api/pleroma/follow_import" do |   describe "POST /api/pleroma/follow_import" do | ||||||
|     test "it returns HTTP 200", %{conn: conn} do |     test "it returns HTTP 200", %{conn: conn} do | ||||||
|       user1 = insert(:user) |       user1 = insert(:user) | ||||||
|  | @ -185,4 +190,26 @@ test "returns json with custom emoji with tags", %{conn: conn} do | ||||||
|       assert is_list(tags) |       assert is_list(tags) | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  | 
 | ||||||
|  |   describe "GET /ostatus_subscribe?acct=...." do | ||||||
|  |     test "adds status to pleroma instance if the `acct` is a status", %{conn: conn} do | ||||||
|  |       conn = | ||||||
|  |         get( | ||||||
|  |           conn, | ||||||
|  |           "/ostatus_subscribe?acct=https://mastodon.social/users/emelie/statuses/101849165031453009" | ||||||
|  |         ) | ||||||
|  | 
 | ||||||
|  |       assert redirected_to(conn) =~ "/notice/" | ||||||
|  |     end | ||||||
|  | 
 | ||||||
|  |     test "show follow account page if the `acct` is a account link", %{conn: conn} do | ||||||
|  |       response = | ||||||
|  |         get( | ||||||
|  |           conn, | ||||||
|  |           "/ostatus_subscribe?acct=https://mastodon.social/users/emelie" | ||||||
|  |         ) | ||||||
|  | 
 | ||||||
|  |       assert html_response(response, 200) =~ "Log in to follow" | ||||||
|  |     end | ||||||
|  |   end | ||||||
| end | end | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Alex S
						Alex S