2020-07-27 10:49:23 +02:00
require 'open-uri'
class DashboardAsyncBlocksController < ApplicationController
before_action :find_dashboard
before_action :find_block
helper :additionals_routes
helper :additionals_queries
helper :queries
helper :issues
helper :activities
helper :dashboards
include DashboardsHelper
2020-10-22 14:56:29 +02:00
# support for redmine_contacts_helpdesk plugin
if Redmine :: Plugin . installed? 'redmine_contacts_helpdesk'
include HelpdeskHelper
helper :helpdesk
end
2020-07-29 16:20:42 +02:00
rescue_from Query :: StatementInvalid , with : :query_statement_invalid
rescue_from StandardError , with : :dashboard_with_invalid_block
2020-07-27 10:49:23 +02:00
def show
2020-07-28 18:15:13 +02:00
@settings [ :sort ] = params [ :sort ] if params [ :sort ] . present?
2020-07-27 10:49:23 +02:00
partial_locals = build_dashboard_partial_locals @block , @block_definition , @settings , @dashboard
respond_to do | format |
format . js do
render partial : partial_locals [ :async ] [ :partial ] ,
content_type : 'text/html' ,
locals : partial_locals
end
end
end
2020-07-28 18:15:13 +02:00
# abuse create for query list sort order support
def create
return render_403 if params [ :sort ] . blank?
partial_locals = build_dashboard_partial_locals @block , @block_definition , @settings , @dashboard
partial_locals [ :sort_options ] = { sort : params [ :sort ] }
respond_to do | format |
format . js do
render partial : 'update_order_by' ,
locals : partial_locals
end
end
end
2020-07-27 10:49:23 +02:00
private
def find_dashboard
@dashboard = Dashboard . find params [ :dashboard_id ]
raise :: Unauthorized unless @dashboard . visible?
if @dashboard . dashboard_type == DashboardContentProject :: TYPE_NAME && @dashboard . project . nil?
@dashboard . content_project = find_project_by_project_id
else
@project = @dashboard . project
deny_access if @project . present? && ! User . current . allowed_to? ( :view_project , @project )
end
@can_edit = @dashboard & . editable?
rescue ActiveRecord :: RecordNotFound
render_404
end
def find_block
@block = params [ 'block' ]
@block_definition = @dashboard . content . find_block @block
2020-07-28 21:35:10 +02:00
2020-07-27 10:49:23 +02:00
render_404 if @block . blank?
render_403 if @block_definition . blank?
@settings = @dashboard . layout_settings @block
end
def find_project_by_project_id
begin
@project = Project . find params [ :project_id ]
rescue ActiveRecord :: RecordNotFound
render_404
end
deny_access unless User . current . allowed_to? ( :view_project , @project )
2020-07-28 21:35:10 +02:00
@project
2020-07-27 10:49:23 +02:00
end
2020-07-29 16:20:42 +02:00
def dashboard_with_invalid_block ( exception )
logger & . error " Invalid dashboard block for #{ @block } : #{ exception . message } "
respond_to do | format |
format . html do
render template : 'dashboards/block_error' , layout : false
end
format . any { head @status }
end
end
2020-07-27 10:49:23 +02:00
end