Enable caching for some rabl views
This commit is contained in:
		
							parent
							
								
									aff22bfdb5
								
							
						
					
					
						commit
						0160d1d9b5
					
				
					 11 changed files with 38 additions and 32 deletions
				
			
		|  | @ -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…
	
	Add table
		
		Reference in a new issue