| 
									
										
										
										
											2011-07-06 16:57:04 +00:00
										 |  |  | # Redmine - project management software | 
					
						
							|  |  |  | # Copyright (C) 2006-2011  Jean-Philippe Lang | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  | # | 
					
						
							|  |  |  | # This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  | # modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  | # as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  | # of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | # | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  | # This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | # but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | # GNU General Public License for more details. | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | # | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  | # You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | # along with this program; if not, write to the Free Software | 
					
						
							|  |  |  | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class QueriesController < ApplicationController | 
					
						
							| 
									
										
										
										
											2008-01-19 11:53:43 +00:00
										 |  |  |   menu_item :issues | 
					
						
							| 
									
										
										
										
											2011-07-06 16:57:04 +00:00
										 |  |  |   before_filter :find_query, :except => [:new, :index] | 
					
						
							| 
									
										
										
										
											2008-03-30 14:20:07 +00:00
										 |  |  |   before_filter :find_optional_project, :only => :new | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-09 08:56:07 +00:00
										 |  |  |   accept_api_auth :index | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-06 16:57:04 +00:00
										 |  |  |   def index | 
					
						
							|  |  |  |     case params[:format] | 
					
						
							|  |  |  |     when 'xml', 'json' | 
					
						
							|  |  |  |       @offset, @limit = api_offset_and_limit | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       @limit = per_page_option | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-06 16:57:04 +00:00
										 |  |  |     @query_count = Query.visible.count | 
					
						
							|  |  |  |     @query_pages = Paginator.new self, @query_count, @limit, params['page'] | 
					
						
							|  |  |  |     @queries = Query.visible.all(:limit => @limit, :offset => @offset, :order => "#{Query.table_name}.name") | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-06 16:57:04 +00:00
										 |  |  |     respond_to do |format| | 
					
						
							|  |  |  |       format.html { render :nothing => true } | 
					
						
							|  |  |  |       format.api | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-23 13:49:29 +00:00
										 |  |  |   def new | 
					
						
							|  |  |  |     @query = Query.new(params[:query]) | 
					
						
							| 
									
										
										
										
											2008-03-30 12:29:07 +00:00
										 |  |  |     @query.project = params[:query_is_for_all] ? nil : @project | 
					
						
							| 
									
										
										
										
											2007-11-20 15:40:16 +00:00
										 |  |  |     @query.user = User.current | 
					
						
							| 
									
										
										
										
											2009-05-10 10:54:31 +00:00
										 |  |  |     @query.is_public = false unless User.current.allowed_to?(:manage_public_queries, @project) || User.current.admin? | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-01 15:00:23 +00:00
										 |  |  |     @query.add_filters(params[:fields] || params[:f], params[:operators] || params[:op], params[:values] || params[:v]) if params[:fields] || params[:f] | 
					
						
							| 
									
										
										
										
											2009-04-26 13:09:14 +00:00
										 |  |  |     @query.group_by ||= params[:group_by] | 
					
						
							| 
									
										
										
										
											2011-04-03 14:31:32 +00:00
										 |  |  |     @query.column_names = params[:c] if params[:c] | 
					
						
							|  |  |  |     @query.column_names = nil if params[:default_columns] | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-03 17:38:18 +00:00
										 |  |  |     if request.post? && params[:confirm] && @query.save | 
					
						
							| 
									
										
										
										
											2007-06-23 13:49:29 +00:00
										 |  |  |       flash[:notice] = l(:notice_successful_create) | 
					
						
							| 
									
										
										
										
											2007-11-05 18:38:42 +00:00
										 |  |  |       redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :query_id => @query | 
					
						
							| 
									
										
										
										
											2007-06-23 13:49:29 +00:00
										 |  |  |       return | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     render :layout => false if request.xhr? | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  |   def edit | 
					
						
							|  |  |  |     if request.post? | 
					
						
							|  |  |  |       @query.filters = {} | 
					
						
							| 
									
										
										
										
											2011-04-01 15:00:23 +00:00
										 |  |  |       @query.add_filters(params[:fields] || params[:f], params[:operators] || params[:op], params[:values] || params[:v]) if params[:fields] || params[:f] | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  |       @query.attributes = params[:query] | 
					
						
							| 
									
										
										
										
											2008-03-30 12:29:07 +00:00
										 |  |  |       @query.project = nil if params[:query_is_for_all] | 
					
						
							| 
									
										
										
										
											2009-05-10 10:54:31 +00:00
										 |  |  |       @query.is_public = false unless User.current.allowed_to?(:manage_public_queries, @project) || User.current.admin? | 
					
						
							| 
									
										
										
										
											2011-04-03 14:31:32 +00:00
										 |  |  |       @query.group_by ||= params[:group_by] | 
					
						
							|  |  |  |       @query.column_names = params[:c] if params[:c] | 
					
						
							| 
									
										
										
										
											2007-10-01 10:44:45 +00:00
										 |  |  |       @query.column_names = nil if params[:default_columns] | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  |       if @query.save | 
					
						
							|  |  |  |         flash[:notice] = l(:notice_successful_update) | 
					
						
							| 
									
										
										
										
											2007-11-05 18:38:42 +00:00
										 |  |  |         redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :query_id => @query | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   def destroy | 
					
						
							|  |  |  |     @query.destroy if request.post? | 
					
						
							| 
									
										
										
										
											2008-03-30 12:29:07 +00:00
										 |  |  |     redirect_to :controller => 'issues', :action => 'index', :project_id => @project, :set_filter => 1
 | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  |   end | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  | private | 
					
						
							| 
									
										
										
										
											2008-03-30 12:29:07 +00:00
										 |  |  |   def find_query | 
					
						
							|  |  |  |     @query = Query.find(params[:id]) | 
					
						
							|  |  |  |     @project = @query.project | 
					
						
							|  |  |  |     render_403 unless @query.editable_by?(User.current) | 
					
						
							|  |  |  |   rescue ActiveRecord::RecordNotFound | 
					
						
							|  |  |  |     render_404 | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2011-08-31 12:02:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-30 14:20:07 +00:00
										 |  |  |   def find_optional_project | 
					
						
							|  |  |  |     @project = Project.find(params[:project_id]) if params[:project_id] | 
					
						
							| 
									
										
										
										
											2010-03-24 20:25:09 +00:00
										 |  |  |     render_403 unless User.current.allowed_to?(:save_queries, @project, :global => true) | 
					
						
							| 
									
										
										
										
											2007-01-02 08:47:07 +00:00
										 |  |  |   rescue ActiveRecord::RecordNotFound | 
					
						
							|  |  |  |     render_404 | 
					
						
							| 
									
										
										
										
											2006-12-16 13:37:32 +00:00
										 |  |  |   end | 
					
						
							|  |  |  | end |