forked from fedi/mastodon
Enable caching for some rabl views
This commit is contained in:
parent
aff22bfdb5
commit
0160d1d9b5
|
@ -205,7 +205,7 @@ GEM
|
||||||
pry-rails (0.3.4)
|
pry-rails (0.3.4)
|
||||||
pry (>= 0.9.10)
|
pry (>= 0.9.10)
|
||||||
puma (3.6.0)
|
puma (3.6.0)
|
||||||
rabl (0.13.0)
|
rabl (0.13.1)
|
||||||
activesupport (>= 2.3.14)
|
activesupport (>= 2.3.14)
|
||||||
rack (2.0.1)
|
rack (2.0.1)
|
||||||
rack-attack (5.0.1)
|
rack-attack (5.0.1)
|
||||||
|
|
|
@ -2,7 +2,7 @@ class Favourite < ApplicationRecord
|
||||||
include Streamable
|
include Streamable
|
||||||
|
|
||||||
belongs_to :account, inverse_of: :favourites
|
belongs_to :account, inverse_of: :favourites
|
||||||
belongs_to :status, inverse_of: :favourites
|
belongs_to :status, inverse_of: :favourites, touch: true
|
||||||
|
|
||||||
validates :status_id, uniqueness: { scope: :account_id }
|
validates :status_id, uniqueness: { scope: :account_id }
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ class Status < ApplicationRecord
|
||||||
belongs_to :account, -> { with_counters }, inverse_of: :statuses
|
belongs_to :account, -> { with_counters }, inverse_of: :statuses
|
||||||
|
|
||||||
belongs_to :thread, foreign_key: 'in_reply_to_id', class_name: 'Status', inverse_of: :replies
|
belongs_to :thread, foreign_key: 'in_reply_to_id', class_name: 'Status', inverse_of: :replies
|
||||||
belongs_to :reblog, foreign_key: 'reblog_of_id', class_name: 'Status', inverse_of: :reblogs
|
belongs_to :reblog, foreign_key: 'reblog_of_id', class_name: 'Status', inverse_of: :reblogs, touch: true
|
||||||
|
|
||||||
has_many :favourites, inverse_of: :status, dependent: :destroy
|
has_many :favourites, inverse_of: :status, dependent: :destroy
|
||||||
has_many :reblogs, foreign_key: 'reblog_of_id', class_name: 'Status', inverse_of: :reblog, dependent: :destroy
|
has_many :reblogs, foreign_key: 'reblog_of_id', class_name: 'Status', inverse_of: :reblog, dependent: :destroy
|
||||||
|
|
|
@ -8,6 +8,6 @@
|
||||||
- if @followers.empty?
|
- if @followers.empty?
|
||||||
= render partial: 'nothing_here'
|
= render partial: 'nothing_here'
|
||||||
- else
|
- else
|
||||||
= render partial: 'grid_card', collection: @followers, as: :account
|
= render partial: 'grid_card', collection: @followers, as: :account, cached: true
|
||||||
|
|
||||||
= will_paginate @followers, pagination_options
|
= will_paginate @followers, pagination_options
|
||||||
|
|
|
@ -9,6 +9,6 @@
|
||||||
- if @following.empty?
|
- if @following.empty?
|
||||||
= render partial: 'nothing_here'
|
= render partial: 'nothing_here'
|
||||||
- else
|
- else
|
||||||
= render partial: 'grid_card', collection: @following, as: :account
|
= render partial: 'grid_card', collection: @following, as: :account, cached: true
|
||||||
|
|
||||||
= will_paginate @following, pagination_options
|
= will_paginate @following, pagination_options
|
||||||
|
|
|
@ -12,6 +12,6 @@
|
||||||
= render partial: 'nothing_here'
|
= render partial: 'nothing_here'
|
||||||
- else
|
- else
|
||||||
.activity-stream
|
.activity-stream
|
||||||
= render partial: 'stream_entries/status', collection: @statuses, as: :status
|
= render partial: 'stream_entries/status', collection: @statuses, as: :status, cached: true
|
||||||
|
|
||||||
= will_paginate @statuses, pagination_options
|
= will_paginate @statuses, pagination_options
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
object @account
|
object @account
|
||||||
|
cache @account
|
||||||
|
|
||||||
attributes :id, :username, :acct, :display_name, :note
|
attributes :id, :username, :acct, :display_name, :note
|
||||||
|
|
||||||
|
|
4
app/views/api/v1/statuses/_media.rabl
Normal file
4
app/views/api/v1/statuses/_media.rabl
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
attributes :id, :remote_url, :type
|
||||||
|
|
||||||
|
node(:url) { |media| full_asset_url(media.file.url) }
|
||||||
|
node(:preview_url) { |media| full_asset_url(media.file.url(:small)) }
|
3
app/views/api/v1/statuses/_mention.rabl
Normal file
3
app/views/api/v1/statuses/_mention.rabl
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
node(:url) { |mention| TagManager.instance.url_for(mention.account) }
|
||||||
|
node(:acct) { |mention| mention.account.acct }
|
||||||
|
node(:id) { |mention| mention.account_id }
|
21
app/views/api/v1/statuses/_show.rabl
Normal file
21
app/views/api/v1/statuses/_show.rabl
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
attributes :id, :created_at, :in_reply_to_id
|
||||||
|
|
||||||
|
node(:uri) { |status| TagManager.instance.uri_for(status) }
|
||||||
|
node(:content) { |status| Formatter.instance.format(status) }
|
||||||
|
node(:url) { |status| TagManager.instance.url_for(status) }
|
||||||
|
node(:reblogs_count) { |status| status.reblogs_count }
|
||||||
|
node(:favourites_count) { |status| status.favourites_count }
|
||||||
|
node(:favourited, if: proc { !current_account.nil? }) { |status| defined?(@favourites_map) ? !!@favourites_map[status.id] : current_account.favourited?(status) }
|
||||||
|
node(:reblogged, if: proc { !current_account.nil? }) { |status| defined?(@reblogs_map) ? !!@reblogs_map[status.id] : current_account.reblogged?(status) }
|
||||||
|
|
||||||
|
child :account do
|
||||||
|
extends 'api/v1/accounts/show'
|
||||||
|
end
|
||||||
|
|
||||||
|
child :media_attachments, object_root: false do
|
||||||
|
extends 'api/v1/statuses/_media'
|
||||||
|
end
|
||||||
|
|
||||||
|
child :mentions, object_root: false do
|
||||||
|
extends 'api/v1/statuses/_mention'
|
||||||
|
end
|
|
@ -1,31 +1,8 @@
|
||||||
object @status
|
object @status
|
||||||
attributes :id, :created_at, :in_reply_to_id
|
cache @status
|
||||||
|
|
||||||
node(:uri) { |status| TagManager.instance.uri_for(status) }
|
extends 'api/v1/statuses/_show'
|
||||||
node(:content) { |status| Formatter.instance.format(status) }
|
|
||||||
node(:url) { |status| TagManager.instance.url_for(status) }
|
|
||||||
node(:reblogs_count) { |status| status.reblogs_count }
|
|
||||||
node(:favourites_count) { |status| status.favourites_count }
|
|
||||||
node(:favourited, if: proc { !current_account.nil? }) { |status| defined?(@favourites_map) ? !!@favourites_map[status.id] : current_account.favourited?(status) }
|
|
||||||
node(:reblogged, if: proc { !current_account.nil? }) { |status| defined?(@reblogs_map) ? !!@reblogs_map[status.id] : current_account.reblogged?(status) }
|
|
||||||
|
|
||||||
child :reblog => :reblog do
|
child :reblog => :reblog do
|
||||||
extends('api/v1/statuses/show')
|
extends 'api/v1/statuses/_show'
|
||||||
end
|
|
||||||
|
|
||||||
child :account do
|
|
||||||
extends('api/v1/accounts/show')
|
|
||||||
end
|
|
||||||
|
|
||||||
child :media_attachments, object_root: false do
|
|
||||||
attributes :id, :remote_url, :type
|
|
||||||
|
|
||||||
node(:url) { |media| full_asset_url(media.file.url) }
|
|
||||||
node(:preview_url) { |media| full_asset_url(media.file.url(:small)) }
|
|
||||||
end
|
|
||||||
|
|
||||||
child :mentions, object_root: false do
|
|
||||||
node(:url) { |mention| TagManager.instance.url_for(mention.account) }
|
|
||||||
node(:acct) { |mention| mention.account.acct }
|
|
||||||
node(:id) { |mention| mention.account_id }
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue