forked from mastodon/mastodon
-
-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'parent/main' into upstream-20240308
- Loading branch information
Showing
106 changed files
with
1,103 additions
and
249 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
37 changes: 37 additions & 0 deletions
37
app/controllers/api/v1/notifications/policies_controller.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
# frozen_string_literal: true | ||
|
||
class Api::V1::Notifications::PoliciesController < Api::BaseController | ||
before_action -> { doorkeeper_authorize! :read, :'read:notifications' }, only: :show | ||
before_action -> { doorkeeper_authorize! :write, :'write:notifications' }, only: :update | ||
|
||
before_action :require_user! | ||
before_action :set_policy | ||
|
||
def show | ||
render json: @policy, serializer: REST::NotificationPolicySerializer | ||
end | ||
|
||
def update | ||
@policy.update!(resource_params) | ||
render json: @policy, serializer: REST::NotificationPolicySerializer | ||
end | ||
|
||
private | ||
|
||
def set_policy | ||
@policy = NotificationPolicy.find_or_initialize_by(account: current_account) | ||
|
||
with_read_replica do | ||
@policy.summarize! | ||
end | ||
end | ||
|
||
def resource_params | ||
params.permit( | ||
:filter_not_following, | ||
:filter_not_followers, | ||
:filter_new_accounts, | ||
:filter_private_mentions | ||
) | ||
end | ||
end |
75 changes: 75 additions & 0 deletions
75
app/controllers/api/v1/notifications/requests_controller.rb
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
# frozen_string_literal: true | ||
|
||
class Api::V1::Notifications::RequestsController < Api::BaseController | ||
before_action -> { doorkeeper_authorize! :read, :'read:notifications' }, only: :index | ||
before_action -> { doorkeeper_authorize! :write, :'write:notifications' }, except: :index | ||
|
||
before_action :require_user! | ||
before_action :set_request, except: :index | ||
|
||
after_action :insert_pagination_headers, only: :index | ||
|
||
def index | ||
with_read_replica do | ||
@requests = load_requests | ||
@relationships = relationships | ||
end | ||
|
||
render json: @requests, each_serializer: REST::NotificationRequestSerializer, relationships: @relationships | ||
end | ||
|
||
def accept | ||
AcceptNotificationRequestService.new.call(@request) | ||
render_empty | ||
end | ||
|
||
def dismiss | ||
@request.update!(dismissed: true) | ||
render_empty | ||
end | ||
|
||
private | ||
|
||
def load_requests | ||
requests = NotificationRequest.where(account: current_account).where(dismissed: truthy_param?(:dismissed)).includes(:last_status, from_account: [:account_stat, :user]).to_a_paginated_by_id( | ||
limit_param(DEFAULT_ACCOUNTS_LIMIT), | ||
params_slice(:max_id, :since_id, :min_id) | ||
) | ||
|
||
NotificationRequest.preload_cache_collection(requests) do |statuses| | ||
cache_collection(statuses, Status) | ||
end | ||
end | ||
|
||
def relationships | ||
StatusRelationshipsPresenter.new(@requests.map(&:last_status), current_user&.account_id) | ||
end | ||
|
||
def set_request | ||
@request = NotificationRequest.where(account: current_account).find(params[:id]) | ||
end | ||
|
||
def insert_pagination_headers | ||
set_pagination_headers(next_path, prev_path) | ||
end | ||
|
||
def next_path | ||
api_v1_notifications_requests_url pagination_params(max_id: pagination_max_id) unless @requests.empty? | ||
end | ||
|
||
def prev_path | ||
api_v1_notifications_requests_url pagination_params(min_id: pagination_since_id) unless @requests.empty? | ||
end | ||
|
||
def pagination_max_id | ||
@requests.last.id | ||
end | ||
|
||
def pagination_since_id | ||
@requests.first.id | ||
end | ||
|
||
def pagination_params(core_params) | ||
params.slice(:dismissed).permit(:dismissed).merge(core_params) | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# frozen_string_literal: true | ||
|
||
# == Schema Information | ||
# | ||
# Table name: notification_permissions | ||
# | ||
# id :bigint(8) not null, primary key | ||
# account_id :bigint(8) not null | ||
# from_account_id :bigint(8) not null | ||
# created_at :datetime not null | ||
# updated_at :datetime not null | ||
# | ||
class NotificationPermission < ApplicationRecord | ||
belongs_to :account | ||
belongs_to :from_account, class_name: 'Account' | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
# frozen_string_literal: true | ||
|
||
# == Schema Information | ||
# | ||
# Table name: notification_policies | ||
# | ||
# id :bigint(8) not null, primary key | ||
# account_id :bigint(8) not null | ||
# filter_not_following :boolean default(FALSE), not null | ||
# filter_not_followers :boolean default(FALSE), not null | ||
# filter_new_accounts :boolean default(FALSE), not null | ||
# filter_private_mentions :boolean default(TRUE), not null | ||
# created_at :datetime not null | ||
# updated_at :datetime not null | ||
# | ||
|
||
class NotificationPolicy < ApplicationRecord | ||
belongs_to :account | ||
|
||
has_many :notification_requests, primary_key: :account_id, foreign_key: :account_id, dependent: nil, inverse_of: false | ||
|
||
attr_reader :pending_requests_count, :pending_notifications_count | ||
|
||
MAX_MEANINGFUL_COUNT = 100 | ||
|
||
def summarize! | ||
@pending_requests_count = pending_notification_requests.first | ||
@pending_notifications_count = pending_notification_requests.last | ||
end | ||
|
||
private | ||
|
||
def pending_notification_requests | ||
@pending_notification_requests ||= notification_requests.where(dismissed: false).limit(MAX_MEANINGFUL_COUNT).pick(Arel.sql('count(*), coalesce(sum(notifications_count), 0)::bigint')) | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
# frozen_string_literal: true | ||
|
||
# == Schema Information | ||
# | ||
# Table name: notification_requests | ||
# | ||
# id :bigint(8) not null, primary key | ||
# account_id :bigint(8) not null | ||
# from_account_id :bigint(8) not null | ||
# last_status_id :bigint(8) not null | ||
# notifications_count :bigint(8) default(0), not null | ||
# dismissed :boolean default(FALSE), not null | ||
# created_at :datetime not null | ||
# updated_at :datetime not null | ||
# | ||
|
||
class NotificationRequest < ApplicationRecord | ||
include Paginable | ||
|
||
MAX_MEANINGFUL_COUNT = 100 | ||
|
||
belongs_to :account | ||
belongs_to :from_account, class_name: 'Account' | ||
belongs_to :last_status, class_name: 'Status' | ||
|
||
before_save :prepare_notifications_count | ||
|
||
def self.preload_cache_collection(requests) | ||
cached_statuses_by_id = yield(requests.filter_map(&:last_status)).index_by(&:id) # Call cache_collection in block | ||
|
||
requests.each do |request| | ||
request.last_status = cached_statuses_by_id[request.last_status_id] unless request.last_status_id.nil? | ||
end | ||
end | ||
|
||
def reconsider_existence! | ||
return if dismissed? | ||
|
||
prepare_notifications_count | ||
|
||
if notifications_count.positive? | ||
save | ||
else | ||
destroy | ||
end | ||
end | ||
|
||
private | ||
|
||
def prepare_notifications_count | ||
self.notifications_count = Notification.where(account: account, from_account: from_account).limit(MAX_MEANINGFUL_COUNT).count | ||
end | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# frozen_string_literal: true | ||
|
||
class REST::NotificationPolicySerializer < ActiveModel::Serializer | ||
attributes :filter_not_following, | ||
:filter_not_followers, | ||
:filter_new_accounts, | ||
:filter_private_mentions, | ||
:summary | ||
|
||
def summary | ||
{ | ||
pending_requests_count: object.pending_requests_count.to_s, | ||
pending_notifications_count: object.pending_notifications_count.to_s, | ||
} | ||
end | ||
end |
Oops, something went wrong.