parent
eef7555d62
commit
e066a9cff5
1 changed files with 49 additions and 52 deletions
|
@ -1,57 +1,54 @@
|
||||||
class Api::V1::InboxMembersController < Api::BaseController
|
module Api
|
||||||
|
module V1
|
||||||
|
class InboxMembersController < Api::BaseController
|
||||||
|
before_action :fetch_inbox, only: [:create, :show]
|
||||||
|
before_action :current_agents_ids, only: [:create]
|
||||||
|
|
||||||
before_action :fetch_inbox, only: [:create, :show]
|
def create
|
||||||
before_action :current_agents_ids, only: [:create]
|
# update also done via same action
|
||||||
|
if @inbox
|
||||||
def create #update also done via same action
|
begin
|
||||||
#get all the user_ids which the inbox currently has as members.
|
update_agents_list
|
||||||
#get the list of user_ids from params
|
head :ok
|
||||||
#the missing ones are the agents which are to be deleted from the inbox
|
rescue StandardError
|
||||||
# the new ones are the agents which are to be added to the inbox
|
render_could_not_create_error('Could not add agents to inbox')
|
||||||
if @inbox
|
end
|
||||||
begin
|
else
|
||||||
add_agents
|
render_not_found_error('Agents or inbox not found')
|
||||||
remove_agents
|
end
|
||||||
head :ok
|
end
|
||||||
rescue => e
|
|
||||||
render_could_not_create_error("Could not add agents to inbox")
|
def show
|
||||||
|
@agents = current_account.users.where(id: @inbox.members.pluck(:user_id))
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def update_agents_list
|
||||||
|
# get all the user_ids which the inbox currently has as members.
|
||||||
|
# get the list of user_ids from params
|
||||||
|
# the missing ones are the agents which are to be deleted from the inbox
|
||||||
|
# the new ones are the agents which are to be added to the inbox
|
||||||
|
|
||||||
|
agents_to_be_added_ids.each { |user_id| @inbox.add_member(user_id) }
|
||||||
|
agents_to_be_removed_ids.each { |_user_id| @inbox.remove_member(user) }
|
||||||
|
end
|
||||||
|
|
||||||
|
def agents_to_be_added_ids
|
||||||
|
params[:user_ids] - @current_agents_ids
|
||||||
|
end
|
||||||
|
|
||||||
|
def agents_to_be_removed_ids
|
||||||
|
@current_agents_ids - params[:user_ids]
|
||||||
|
end
|
||||||
|
|
||||||
|
def current_agents_ids
|
||||||
|
@current_agents_ids = @inbox.members.pluck(:user_id)
|
||||||
|
end
|
||||||
|
|
||||||
|
def fetch_inbox
|
||||||
|
@inbox = current_account.inboxes.find(params[:inbox_id])
|
||||||
end
|
end
|
||||||
else
|
|
||||||
render_not_found_error("Agents or inbox not found")
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def show
|
|
||||||
@agents = current_account.users.where(id: @inbox.members.pluck(:user_id))
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def add_agents
|
|
||||||
agents_to_be_added_ids.each do |user_id|
|
|
||||||
@inbox.add_member(user_id)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def remove_agents
|
|
||||||
agents_to_be_removed_ids.each do |user_id|
|
|
||||||
@inbox.remove_member(user)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def agents_to_be_added_ids
|
|
||||||
params[:user_ids] - @current_agents_ids
|
|
||||||
end
|
|
||||||
|
|
||||||
def agents_to_be_removed_ids
|
|
||||||
@current_agents_ids - params[:user_ids]
|
|
||||||
end
|
|
||||||
|
|
||||||
def current_agents_ids
|
|
||||||
@current_agents_ids = @inbox.members.pluck(:user_id)
|
|
||||||
end
|
|
||||||
|
|
||||||
def fetch_inbox
|
|
||||||
@inbox = current_account.inboxes.find(params[:inbox_id])
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue