diff options
author | Fire Demon <firedemon@creature.cafe> | 2020-09-20 22:52:50 -0500 |
---|---|---|
committer | Fire Demon <firedemon@creature.cafe> | 2020-09-20 23:07:30 -0500 |
commit | 64694de343737360e797a92a0a6c0e88695facda (patch) | |
tree | e31a8d7eb5cb909be89df96e8185b20183ed5a22 /app/models | |
parent | e3cb18ba7520997a0f605c7f90db258ccccd5e33 (diff) |
Monsterfork v1-style curated Federated timeline
Diffstat (limited to 'app/models')
-rw-r--r-- | app/models/public_feed.rb | 7 | ||||
-rw-r--r-- | app/models/status.rb | 10 |
2 files changed, 16 insertions, 1 deletions
diff --git a/app/models/public_feed.rb b/app/models/public_feed.rb index 2839da5cb..afde8aa65 100644 --- a/app/models/public_feed.rb +++ b/app/models/public_feed.rb @@ -26,7 +26,8 @@ class PublicFeed < Feed scope.merge!(without_replies_scope) unless with_replies? scope.merge!(without_reblogs_scope) unless with_reblogs? scope.merge!(local_only_scope) if local_only? - scope.merge!(remote_only_scope) if remote_only? + #scope.merge!(remote_only_scope) if remote_only? + scope.merge!(curated_scope) unless remote_only? scope.merge!(account_filters_scope) if account? scope.merge!(media_only_scope) if media_only? @@ -79,6 +80,10 @@ class PublicFeed < Feed Status.remote end + def curated_scope + Status.curated + end + def without_replies_scope Status.without_replies end diff --git a/app/models/status.rb b/app/models/status.rb index c79cbeaf9..ba8b4ff2b 100644 --- a/app/models/status.rb +++ b/app/models/status.rb @@ -35,6 +35,7 @@ # expires_at :datetime # publish_at :datetime # originally_local_only :boolean default(FALSE), not null +# curated :boolean default(FALSE), not null # # rubocop:disable Metrics/ClassLength @@ -142,6 +143,7 @@ class Status < ApplicationRecord scope :replies, -> { where(reply: true) } scope :expired, -> { published.where('statuses.expires_at IS NOT NULL AND statuses.expires_at < ?', Time.now.utc) } scope :ready_to_publish, -> { unpublished.where('statuses.publish_at IS NOT NULL AND statuses.publish_at < ?', Time.now.utc) } + scope :curated, -> { where(curated: true) } scope :not_hidden_by_account, ->(account) do left_outer_joins(:mutes, :conversation_mute).where('(status_mutes.account_id IS NULL OR status_mutes.account_id != ?) AND (conversation_mutes.account_id IS NULL OR conversation_mutes.account_id != ?)', account.id, account.id) @@ -308,6 +310,14 @@ class Status < ApplicationRecord update_status_stat!(key => [public_send(key) - 1, 0].max) end + def curate! + update_column(:curated, true) if public_visibility? && !curated + end + + def uncurate! + update_column(:curated, false) if curated + end + def notify=(value) Redis.current.set("status:#{id}:notify", value ? 1 : 0, ex: 1.hour) @notify = value |