diff options
author | multiple creatures <dev@multiple-creature.party> | 2019-04-13 23:17:51 -0500 |
---|---|---|
committer | multiple creatures <dev@multiple-creature.party> | 2019-05-21 03:16:21 -0500 |
commit | dd5e02ad5d79e4fc2163a9bcd009859e9c2a4466 (patch) | |
tree | f8d2aa407ff53805408f0cbc17d7d25a7f28ea23 /app/models | |
parent | 4c170d2a98e4a289ad40580785cbeb892bd68eab (diff) |
Use PostgreSQL FTS for searches.
Diffstat (limited to 'app/models')
-rw-r--r-- | app/models/status.rb | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/app/models/status.rb b/app/models/status.rb index 45db988e3..7679fd60f 100644 --- a/app/models/status.rb +++ b/app/models/status.rb @@ -298,6 +298,23 @@ class Status < ApplicationRecord after_find :limit_domain_visibility class << self + def search_for(term, limit = 33, account = nil) + pattern = sanitize_sql_like(term) + pattern = "#{pattern}" + Status.unscoped { + scope = Status.where("tsv @@ plainto_tsquery('english', ?)", pattern) + query = scope.where(visibility: :public) + if account.present? + query = query + .or(scope.where(account: account)) + .or(scope.where(account: account.following, visibility: [:unlisted, :private])) + .or(scope.where(id: account.mentions.select(:status_id))) + end + query = query.where(reblog_of_id: nil).order(id: :desc).limit(limit) + apply_timeline_filters(query, account, true) + } + end + def selectable_visibilities visibilities.keys - %w(direct limited) end |