3ebc0ad4d3
* 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
|