* Add full-text search for authorized statuses - Search API will return statuses that match the query - Only for logged in users - Only if you are author of the status, - Or you were mentioned in it - Or you favourited or reblogged it - Configuration over `ES_ENABLED`, `ES_HOST`, `ES_PORT`, `ES_PREFIX` - Run `rails chewy:deploy` to create & populate index Fix #5880 Fix #4293 Fix #1152 * Add commented out docker-compose configuration for ES container * Optimize index import, filter search results * Add basic normalization to the index * Add better stemming and normalization to the index * Skip webfinger request if search query includes both @ and a space * Fix code style * Visually separate search result sections * Fix code style issues
		
			
				
	
	
		
			28 lines
		
	
	
	
		
			744 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
	
		
			744 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
# frozen_string_literal: true
 | 
						|
# == Schema Information
 | 
						|
#
 | 
						|
# Table name: favourites
 | 
						|
#
 | 
						|
#  id         :integer          not null, primary key
 | 
						|
#  created_at :datetime         not null
 | 
						|
#  updated_at :datetime         not null
 | 
						|
#  account_id :integer          not null
 | 
						|
#  status_id  :integer          not null
 | 
						|
#
 | 
						|
 | 
						|
class Favourite < ApplicationRecord
 | 
						|
  include Paginable
 | 
						|
 | 
						|
  update_index('statuses#status', :status) if Chewy.enabled?
 | 
						|
 | 
						|
  belongs_to :account, inverse_of: :favourites
 | 
						|
  belongs_to :status,  inverse_of: :favourites, counter_cache: true
 | 
						|
 | 
						|
  has_one :notification, as: :activity, dependent: :destroy
 | 
						|
 | 
						|
  validates :status_id, uniqueness: { scope: :account_id }
 | 
						|
 | 
						|
  before_validation do
 | 
						|
    self.status = status.reblog if status&.reblog?
 | 
						|
  end
 | 
						|
end
 |