FIX: allow admin to change topic notification level via API (#21581)

* FIX: allow admin to change topic notification level via API

* default to `current_user` if admin changes own level

* check param existence

* simplify condition

* remove rescue

* Update spec/requests/topics_controller_spec.rb

Co-authored-by: Penar Musaraj <pmusaraj@gmail.com>

* added specs for other cases

---------

Co-authored-by: Penar Musaraj <pmusaraj@gmail.com>
This commit is contained in:
Faizaan Gagan 2023-05-23 00:47:58 +05:30 committed by GitHub
parent efdfddf7fc
commit a58c37bdc5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 81 additions and 1 deletions

View File

@ -803,8 +803,16 @@ class TopicsController < ApplicationController
end end
def set_notifications def set_notifications
user =
if is_api? && @guardian.is_admin? &&
(params[:username].present? || params[:external_id].present?)
fetch_user_from_params
else
current_user
end
topic = Topic.find(params[:topic_id].to_i) topic = Topic.find(params[:topic_id].to_i)
TopicUser.change(current_user, topic.id, notification_level: params[:notification_level].to_i) TopicUser.change(user, topic.id, notification_level: params[:notification_level].to_i)
render json: success_json render json: success_json
end end

View File

@ -4841,4 +4841,76 @@ RSpec.describe TopicsController do
expect(body["group_name"]).to eq(group.name) expect(body["group_name"]).to eq(group.name)
end end
end end
describe "#set_notifications" do
describe "initiated by admin" do
it "can update another user's notification level via API" do
api_key = Fabricate(:api_key, user: admin)
post "/t/#{topic.id}/notifications",
params: {
username: user.username,
notification_level: NotificationLevels.topic_levels[:watching],
},
headers: {
HTTP_API_KEY: api_key.key,
HTTP_API_USERNAME: admin.username,
}
expect(TopicUser.find_by(user: user, topic: topic).notification_level).to eq(
NotificationLevels.topic_levels[:watching],
)
end
it "can update own notification level via API" do
api_key = Fabricate(:api_key, user: admin)
post "/t/#{topic.id}/notifications",
params: {
notification_level: NotificationLevels.topic_levels[:watching],
},
headers: {
HTTP_API_KEY: api_key.key,
HTTP_API_USERNAME: admin.username,
}
expect(TopicUser.find_by(user: admin, topic: topic).notification_level).to eq(
NotificationLevels.topic_levels[:watching],
)
end
end
describe "initiated by non-admin" do
it "only acts on current_user and ignores `username` param" do
sign_in(user)
TopicUser.create!(
user: user,
topic: topic,
notification_level: NotificationLevels.topic_levels[:tracking],
)
post "/t/#{topic.id}/notifications.json",
params: {
username: user_2.username,
notification_level: NotificationLevels.topic_levels[:watching],
}
expect(TopicUser.find_by(user: user, topic: topic).notification_level).to eq(
NotificationLevels.topic_levels[:watching],
)
expect(TopicUser.find_by(user: user_2, topic: topic)).to be_blank
end
it "can update own notification level via API" do
api_key = Fabricate(:api_key, user: user)
post "/t/#{topic.id}/notifications",
params: {
notification_level: NotificationLevels.topic_levels[:watching],
},
headers: {
HTTP_API_KEY: api_key.key,
HTTP_API_USERNAME: user.username,
}
expect(TopicUser.find_by(user: user, topic: topic).notification_level).to eq(
NotificationLevels.topic_levels[:watching],
)
end
end
end
end end