Chris@1296: # Redmine - project management software Chris@1296: # Copyright (C) 2006-2012 Jean-Philippe Lang Chris@1296: # Chris@1296: # This program is free software; you can redistribute it and/or Chris@1296: # modify it under the terms of the GNU General Public License Chris@1296: # as published by the Free Software Foundation; either version 2 Chris@1296: # of the License, or (at your option) any later version. Chris@1296: # Chris@1296: # This program is distributed in the hope that it will be useful, Chris@1296: # but WITHOUT ANY WARRANTY; without even the implied warranty of Chris@1296: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the Chris@1296: # GNU General Public License for more details. Chris@1296: # Chris@1296: # You should have received a copy of the GNU General Public License Chris@1296: # along with this program; if not, write to the Free Software Chris@1296: # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Chris@1296: Chris@1296: class QueriesController < ApplicationController Chris@1296: menu_item :issues Chris@1296: before_filter :find_query, :except => [:new, :create, :index] Chris@1296: before_filter :find_optional_project, :only => [:new, :create] Chris@1296: Chris@1296: accept_api_auth :index Chris@1296: Chris@1296: include QueriesHelper Chris@1296: Chris@1296: def index Chris@1296: case params[:format] Chris@1296: when 'xml', 'json' Chris@1296: @offset, @limit = api_offset_and_limit Chris@1296: else Chris@1296: @limit = per_page_option Chris@1296: end Chris@1296: Chris@1296: @query_count = Query.visible.count Chris@1296: @query_pages = Paginator.new self, @query_count, @limit, params['page'] Chris@1296: @queries = Query.visible.all(:limit => @limit, :offset => @offset, :order => "#{Query.table_name}.name") Chris@1296: Chris@1296: respond_to do |format| Chris@1296: format.html { render :nothing => true } Chris@1296: format.api Chris@1296: end Chris@1296: end Chris@1296: Chris@1296: def new Chris@1296: @query = Query.new Chris@1296: @query.user = User.current Chris@1296: @query.project = @project Chris@1296: @query.is_public = false unless User.current.allowed_to?(:manage_public_queries, @project) || User.current.admin? Chris@1296: build_query_from_params Chris@1296: end Chris@1296: Chris@1296: def create Chris@1296: @query = Query.new(params[:query]) Chris@1296: @query.user = User.current Chris@1296: @query.project = params[:query_is_for_all] ? nil : @project Chris@1296: @query.is_public = false unless User.current.allowed_to?(:manage_public_queries, @project) || User.current.admin? Chris@1296: build_query_from_params Chris@1296: @query.column_names = nil if params[:default_columns] Chris@1296: Chris@1296: if @query.save Chris@1296: flash[:notice] = l(:notice_successful_create) Chris@1296: redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :query_id => @query Chris@1296: else Chris@1296: render :action => 'new', :layout => !request.xhr? Chris@1296: end Chris@1296: end Chris@1296: Chris@1296: def edit Chris@1296: end Chris@1296: Chris@1296: def update Chris@1296: @query.attributes = params[:query] Chris@1296: @query.project = nil if params[:query_is_for_all] Chris@1296: @query.is_public = false unless User.current.allowed_to?(:manage_public_queries, @project) || User.current.admin? Chris@1296: build_query_from_params Chris@1296: @query.column_names = nil if params[:default_columns] Chris@1296: Chris@1296: if @query.save Chris@1296: flash[:notice] = l(:notice_successful_update) Chris@1296: redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :query_id => @query Chris@1296: else Chris@1296: render :action => 'edit' Chris@1296: end Chris@1296: end Chris@1296: Chris@1296: def destroy Chris@1296: @query.destroy Chris@1296: redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :set_filter => 1 Chris@1296: end Chris@1296: Chris@1296: private Chris@1296: def find_query Chris@1296: @query = Query.find(params[:id]) Chris@1296: @project = @query.project Chris@1296: render_403 unless @query.editable_by?(User.current) Chris@1296: rescue ActiveRecord::RecordNotFound Chris@1296: render_404 Chris@1296: end Chris@1296: Chris@1296: def find_optional_project Chris@1296: @project = Project.find(params[:project_id]) if params[:project_id] Chris@1296: render_403 unless User.current.allowed_to?(:save_queries, @project, :global => true) Chris@1296: rescue ActiveRecord::RecordNotFound Chris@1296: render_404 Chris@1296: end Chris@1296: end