scinote-web/app/controllers/user_projects_controller.rb

175 lines
4.2 KiB
Ruby
Raw Normal View History

2016-02-12 23:52:43 +08:00
class UserProjectsController < ApplicationController
2016-11-07 22:31:06 +08:00
include NotificationsHelper
include InputSanitizeHelper
2016-11-07 22:31:06 +08:00
2016-02-12 23:52:43 +08:00
before_action :load_vars
2018-11-09 18:36:44 +08:00
before_action :load_up_var, only: %i(update destroy)
before_action :check_view_permissions, only: :index
before_action :check_manage_users_permissions, only: :index_edit
before_action :check_create_permissions, only: :create
2018-11-09 18:36:44 +08:00
before_action :check_manage_permissions, only: %i(update destroy)
2016-02-12 23:52:43 +08:00
def index
@users = @project.user_projects
respond_to do |format|
format.json do
render json: {
html: render_to_string(
partial: 'index.html.erb'
),
project_id: @project.id,
2017-05-09 16:18:57 +08:00
counter: @project.users.count # Used for counter badge
2016-02-12 23:52:43 +08:00
}
end
2016-02-12 23:52:43 +08:00
end
end
def index_edit
@users = @project.user_projects
@unassigned_users = @project.unassigned_users
@up = UserProject.new(project: @project)
respond_to do |format|
format.json do
render json: {
project: @project,
html_header: t('projects.index.modal_manage_users.modal_title_html',
name: @project.name),
html_body: render_to_string(
partial: 'index_edit.html.erb'
),
html_footer: render_to_string(
partial: 'index_edit_footer.html.erb'
)
2016-02-12 23:52:43 +08:00
}
end
2016-02-12 23:52:43 +08:00
end
end
def create
@up = UserProject.new(up_params.merge(project: @project))
@up.assigned_by = current_user
if @up.save
2019-03-08 00:26:42 +08:00
log_activity(:assign_user_to_project)
2016-02-12 23:52:43 +08:00
respond_to do |format|
format.json do
redirect_to project_users_edit_path(format: :json), turbolinks: false
end
2016-02-12 23:52:43 +08:00
end
else
error = t('user_projects.create.can_add_user_to_project')
error = t('user_projects.create.select_user_role') unless @up.role
respond_to do |format|
format.json {
render :json => {
status: 'error',
2016-11-23 20:19:10 +08:00
error: error
2016-02-12 23:52:43 +08:00
}
}
end
end
end
def update
@up.role = up_params[:role]
if @up.save
2019-03-08 00:26:42 +08:00
log_activity(:change_user_role_on_project)
2016-02-12 23:52:43 +08:00
respond_to do |format|
format.json do
redirect_to project_users_edit_path(format: :json), turbolinks: false
end
2016-02-12 23:52:43 +08:00
end
else
respond_to do |format|
format.json do
render json: {
2016-02-12 23:52:43 +08:00
status: 'error',
errors: @up.errors
2016-02-12 23:52:43 +08:00
}
end
2016-02-12 23:52:43 +08:00
end
end
end
def destroy
if @up.destroy
2019-03-08 00:26:42 +08:00
log_activity(:unassign_user_from_project)
generate_notification(current_user,
@up.user,
false,
@up.role_str,
@project)
2016-02-12 23:52:43 +08:00
respond_to do |format|
format.json do
redirect_to project_users_edit_path(format: :json),
turbolinks: false,
status: 303
end
2016-02-12 23:52:43 +08:00
end
else
respond_to do |format|
format.json do
render json: {
errors: @up.errors
2016-02-12 23:52:43 +08:00
}
end
2016-02-12 23:52:43 +08:00
end
end
end
private
def load_vars
@project = Project.find_by_id(params[:project_id])
2018-11-09 18:36:44 +08:00
render_404 unless @project
end
2016-02-12 23:52:43 +08:00
2018-11-09 18:36:44 +08:00
def load_up_var
@up = UserProject.find(params[:id])
render_404 unless @up
2016-02-12 23:52:43 +08:00
end
def check_view_permissions
render_403 unless can_read_project?(@project)
2016-02-12 23:52:43 +08:00
end
def check_manage_users_permissions
render_403 unless can_manage_project?(@project)
end
2016-02-12 23:52:43 +08:00
def check_create_permissions
render_403 unless can_create_projects?(current_team)
2016-02-12 23:52:43 +08:00
end
2018-11-09 18:36:44 +08:00
def check_manage_permissions
render_403 unless can_manage_project?(@project) &&
@up.user_id != current_user.id
2016-02-12 23:52:43 +08:00
end
def init_gui
@users = @project.unassigned_users
end
def up_params
params.require(:user_project).permit(:user_id, :project_id, :role)
end
2019-03-08 00:26:42 +08:00
def log_activity(type_of)
Activities::CreateActivityService
.call(activity_type: type_of,
owner: current_user,
subject: @project,
team: @project.team,
project: @project,
message_items: { project: @project.id,
user_target: @up.user.id,
role: @up.role_str })
end
2016-02-12 23:52:43 +08:00
end