API addition: HTTP PATCH support for /groups/xxx: incremental membership changes
This commit is contained in:
parent
82a6e3aedc
commit
50de22801f
|
@ -20,18 +20,36 @@ class Admin::GroupsController < Admin::AdminController
|
||||||
render json: success_json
|
render json: success_json
|
||||||
end
|
end
|
||||||
|
|
||||||
def update
|
def update_patch(group)
|
||||||
group = Group.find(params[:id].to_i)
|
raise Discourse::InvalidAccess.new("automatic groups do not permit membership changes") if group.automatic
|
||||||
|
|
||||||
group.alias_level = params[:group][:alias_level].to_i if params[:group][:alias_level].present?
|
actions = params[:changes]
|
||||||
|
Array(actions[:add]).each do |username|
|
||||||
|
if user = User.find_by_username(username)
|
||||||
|
group.add(user)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
Array(actions[:delete]).each do |username|
|
||||||
|
if user = User.find_by_username(username)
|
||||||
|
group.remove(user)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
render json: success_json
|
||||||
|
end
|
||||||
|
|
||||||
|
def update_put(group)
|
||||||
|
payload = params[:group]
|
||||||
|
|
||||||
|
group.alias_level = payload[:alias_level].to_i if payload[:alias_level].present?
|
||||||
|
group.visible = payload[:visible] == "true"
|
||||||
|
|
||||||
if group.automatic
|
if group.automatic
|
||||||
# we can only change the alias level on automatic groups
|
# group rename & membership changes are ignored/prohibited for automatic groups
|
||||||
else
|
else
|
||||||
group.usernames = params[:group][:usernames]
|
group.usernames = payload[:usernames] if payload[:usernames]
|
||||||
group.name = params[:group][:name] if params[:group][:name]
|
group.name = payload[:name] if payload[:name]
|
||||||
end
|
end
|
||||||
group.visible = params[:group][:visible] == "true"
|
|
||||||
|
|
||||||
if group.save
|
if group.save
|
||||||
render json: success_json
|
render json: success_json
|
||||||
|
@ -40,6 +58,16 @@ class Admin::GroupsController < Admin::AdminController
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def update
|
||||||
|
group = Group.find(params[:id].to_i)
|
||||||
|
|
||||||
|
if request.patch?
|
||||||
|
update_patch(group)
|
||||||
|
else
|
||||||
|
update_put(group)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def create
|
def create
|
||||||
group = Group.new
|
group = Group.new
|
||||||
group.name = (params[:group][:name] || '').strip
|
group.name = (params[:group][:name] || '').strip
|
||||||
|
|
|
@ -273,6 +273,10 @@ class Group < ActiveRecord::Base
|
||||||
self.users.push(user)
|
self.users.push(user)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def remove(user)
|
||||||
|
self.group_users.where(user: user).each(&:destroy)
|
||||||
|
end
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def name_format_validator
|
def name_format_validator
|
||||||
|
|
|
@ -79,10 +79,12 @@ describe Admin::GroupsController do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context '.update' do
|
||||||
|
let (:group) { Fabricate(:group) }
|
||||||
|
|
||||||
it "is able to update group members" do
|
it "is able to update group members" do
|
||||||
user1 = Fabricate(:user)
|
user1 = Fabricate(:user)
|
||||||
user2 = Fabricate(:user)
|
user2 = Fabricate(:user)
|
||||||
group = Fabricate(:group)
|
|
||||||
|
|
||||||
xhr :put, :update, id: group.id, name: 'fred', group: {
|
xhr :put, :update, id: group.id, name: 'fred', group: {
|
||||||
name: 'fred',
|
name: 'fred',
|
||||||
|
@ -93,4 +95,50 @@ describe Admin::GroupsController do
|
||||||
group.users.count.should == 2
|
group.users.count.should == 2
|
||||||
group.name.should == 'fred'
|
group.name.should == 'fred'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'incremental' do
|
||||||
|
before do
|
||||||
|
@user1 = Fabricate(:user)
|
||||||
|
group.add(@user1)
|
||||||
|
group.reload
|
||||||
|
end
|
||||||
|
|
||||||
|
it "can make incremental adds" do
|
||||||
|
user2 = Fabricate(:user)
|
||||||
|
xhr :patch, :update, id: group.id, changes: {add: user2.username}
|
||||||
|
response.status.should == 200
|
||||||
|
group.reload
|
||||||
|
group.users.count.should eq(2)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "succeeds silently when adding non-existent users" do
|
||||||
|
xhr :patch, :update, id: group.id, changes: {add: "nosuchperson"}
|
||||||
|
response.status.should == 200
|
||||||
|
group.reload
|
||||||
|
group.users.count.should eq(1)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "can make incremental deletes" do
|
||||||
|
xhr :patch, :update, id: group.id, changes: {delete: @user1.username}
|
||||||
|
response.status.should == 200
|
||||||
|
group.reload
|
||||||
|
group.users.count.should eq(0)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "succeeds silently when removing non-members" do
|
||||||
|
user2 = Fabricate(:user)
|
||||||
|
xhr :patch, :update, id: group.id, changes: {delete: user2.username}
|
||||||
|
response.status.should == 200
|
||||||
|
group.reload
|
||||||
|
group.users.count.should eq(1)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "cannot patch automatic groups" do
|
||||||
|
auto_group = Fabricate(:group, name: "auto_group", automatic: true)
|
||||||
|
|
||||||
|
xhr :patch, :update, id: auto_group.id, changes: {add: "bob"}
|
||||||
|
response.status.should == 403
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue