Merge upstream 2.0ish #165

This commit is contained in:
kibigo!
2017-10-11 10:43:10 -07:00
322 changed files with 8478 additions and 2587 deletions

View File

@ -3,10 +3,11 @@
class ActivityPub::ActivitySerializer < ActiveModel::Serializer
attributes :id, :type, :actor, :published, :to, :cc
has_one :proper, key: :object, serializer: ActivityPub::NoteSerializer
has_one :proper, key: :object, serializer: ActivityPub::NoteSerializer, unless: :announce?
attribute :proper_uri, key: :object, if: :announce?
def id
[ActivityPub::TagManager.instance.activity_uri_for(object)].join
ActivityPub::TagManager.instance.activity_uri_for(object)
end
def type
@ -29,6 +30,10 @@ class ActivityPub::ActivitySerializer < ActiveModel::Serializer
ActivityPub::TagManager.instance.cc(object)
end
def proper_uri
ActivityPub::TagManager.instance.uri_for(object.proper)
end
def announce?
object.reblog?
end

View File

@ -10,20 +10,6 @@ class ActivityPub::ActorSerializer < ActiveModel::Serializer
has_one :public_key, serializer: ActivityPub::PublicKeySerializer
class ImageSerializer < ActiveModel::Serializer
include RoutingHelper
attributes :type, :url
def type
'Image'
end
def url
full_asset_url(object.url(:original))
end
end
class EndpointsSerializer < ActiveModel::Serializer
include RoutingHelper
@ -36,8 +22,8 @@ class ActivityPub::ActorSerializer < ActiveModel::Serializer
has_one :endpoints, serializer: EndpointsSerializer
has_one :icon, serializer: ImageSerializer, if: :avatar_exists?
has_one :image, serializer: ImageSerializer, if: :header_exists?
has_one :icon, serializer: ActivityPub::ImageSerializer, if: :avatar_exists?
has_one :image, serializer: ActivityPub::ImageSerializer, if: :header_exists?
def id
account_url(object)

View File

@ -0,0 +1,29 @@
# frozen_string_literal: true
class ActivityPub::EmojiSerializer < ActiveModel::Serializer
include RoutingHelper
attributes :id, :type, :name, :updated
has_one :icon, serializer: ActivityPub::ImageSerializer
def id
ActivityPub::TagManager.instance.uri_for(object)
end
def type
'Emoji'
end
def icon
object.image
end
def updated
object.updated_at.iso8601
end
def name
":#{object.shortcode}:"
end
end

View File

@ -0,0 +1,19 @@
# frozen_string_literal: true
class ActivityPub::ImageSerializer < ActiveModel::Serializer
include RoutingHelper
attributes :type, :media_type, :url
def type
'Image'
end
def url
full_asset_url(object.url(:original))
end
def media_type
object.content_type
end
end

View File

@ -89,12 +89,16 @@ class ActivityPub::NoteSerializer < ActiveModel::Serializer
class MediaAttachmentSerializer < ActiveModel::Serializer
include RoutingHelper
attributes :type, :media_type, :url
attributes :type, :media_type, :url, :name
def type
'Document'
end
def name
object.description
end
def media_type
object.file_content_type
end
@ -138,21 +142,6 @@ class ActivityPub::NoteSerializer < ActiveModel::Serializer
end
end
class CustomEmojiSerializer < ActiveModel::Serializer
include RoutingHelper
attributes :type, :href, :name
def type
'Emoji'
end
def href
full_asset_url(object.image.url)
end
def name
":#{object.shortcode}:"
end
class CustomEmojiSerializer < ActivityPub::EmojiSerializer
end
end

View File

@ -0,0 +1,52 @@
# frozen_string_literal: true
class ManifestSerializer < ActiveModel::Serializer
include RoutingHelper
include ActionView::Helpers::TextHelper
attributes :name, :short_name, :description,
:icons, :theme_color, :background_color,
:display, :start_url, :scope
def name
object.site_title
end
def short_name
object.site_title
end
def description
strip_tags(object.site_description.presence || I18n.t('about.about_mastodon_html'))
end
def icons
[
{
src: '/android-chrome-192x192.png',
sizes: '192x192',
type: 'image/png',
},
]
end
def theme_color
'#282c37'
end
def background_color
'#191b22'
end
def display
'standalone'
end
def start_url
'/web/timelines/home'
end
def scope
root_url
end
end

View File

@ -15,4 +15,8 @@ class REST::ApplicationSerializer < ActiveModel::Serializer
def client_secret
object.secret
end
def website
object.website.presence
end
end

View File

@ -3,9 +3,13 @@
class REST::CustomEmojiSerializer < ActiveModel::Serializer
include RoutingHelper
attributes :shortcode, :url
attributes :shortcode, :url, :static_url
def url
full_asset_url(object.image.url)
end
def static_url
full_asset_url(object.image.url(:static))
end
end

View File

@ -4,7 +4,8 @@ class REST::MediaAttachmentSerializer < ActiveModel::Serializer
include RoutingHelper
attributes :id, :type, :url, :preview_url,
:remote_url, :text_url, :meta
:remote_url, :text_url, :meta,
:description
def id
object.id.to_s
@ -18,6 +19,10 @@ class REST::MediaAttachmentSerializer < ActiveModel::Serializer
end
end
def remote_url
object.remote_url.presence
end
def preview_url
if object.needs_redownload?
media_proxy_url(object.id, :small)