From 0dbee87afa49c3c5f75f045e1ac5bf1ec171e5b7 Mon Sep 17 00:00:00 2001 From: Simon Brandhof Date: Mon, 15 Aug 2011 17:13:50 +0200 Subject: SONAR-2412 add support of project deletion from the Java web service client --- .../src/main/webapp/WEB-INF/app/models/project.rb | 76 +++++++++++----------- 1 file changed, 39 insertions(+), 37 deletions(-) (limited to 'sonar-server') diff --git a/sonar-server/src/main/webapp/WEB-INF/app/models/project.rb b/sonar-server/src/main/webapp/WEB-INF/app/models/project.rb index 5fd8dde7209..01b358e17ce 100644 --- a/sonar-server/src/main/webapp/WEB-INF/app/models/project.rb +++ b/sonar-server/src/main/webapp/WEB-INF/app/models/project.rb @@ -20,7 +20,7 @@ class Project < ActiveRecord::Base include Comparable include Resourceable - + has_many :snapshots has_many :processed_snapshots, :class_name => 'Snapshot', :conditions => "status='#{Snapshot::STATUS_PROCESSED}' AND qualifier<>'LIB'", :order => 'created_at asc' has_many :events, :foreign_key => 'resource_id', :order => 'event_date DESC' @@ -41,36 +41,38 @@ class Project < ActiveRecord::Base end def self.delete_project(project) + if project Snapshot.update_all(['islast=?', false], ['(root_project_id=? OR project_id=?) AND islast=?', project.id, project.id, true]) Project.delete_all(['id=? OR root_id=? or copy_resource_id=?', project.id, project.id, project.id]) + end end - + def project root||self end - + def root_project - @root_project ||= - begin - parent_module(self) - end + @root_project ||= + begin + parent_module(self) + end end - + def last_snapshot @last_snapshot ||= - begin - snapshot=Snapshot.find(:first, :conditions => {:islast => true, :project_id => id}) - if snapshot - snapshot.project=self + begin + snapshot=Snapshot.find(:first, :conditions => {:islast => true, :project_id => id}) + if snapshot + snapshot.project=self + end + snapshot end - snapshot - end end - + def events_with_snapshot - events.select{|event| !event.snapshot_id.nil?} + events.select { |event| !event.snapshot_id.nil? } end - + def key kee end @@ -78,29 +80,29 @@ class Project < ActiveRecord::Base def links project_links end - + def link(type) # to_a avoids conflicts with ActiveRecord:Base.find - links.to_a.find{ |l| l.link_type==type} - end - + links.to_a.find { |l| l.link_type==type } + end + def custom_links - links.select {|l| l.custom?} + links.select { |l| l.custom? } end - + def standard_links - links.reject {|l| l.custom?} + links.reject { |l| l.custom? } end def chart_measures(metric_id) sql = Project.send(:sanitize_sql, ['select s.created_at as created_at, m.value as value ' + - ' from project_measures m, snapshots s ' + - ' where s.id=m.snapshot_id and ' + - " s.status='%s' and " + - ' s.project_id=%s and m.metric_id=%s ', Snapshot::STATUS_PROCESSED, self.id, metric_id] ) + - ' and m.rule_id IS NULL and m.rule_priority IS NULL' + - ' order by s.created_at' - create_chart_measures( Project.connection.select_all( sql ), 'created_at', 'value' ) + ' from project_measures m, snapshots s ' + + ' where s.id=m.snapshot_id and ' + + " s.status='%s' and " + + ' s.project_id=%s and m.metric_id=%s ', Snapshot::STATUS_PROCESSED, self.id, metric_id]) + + ' and m.rule_id IS NULL and m.rule_priority IS NULL' + + ' order by s.created_at' + create_chart_measures(Project.connection.select_all(sql), 'created_at', 'value') end def <=>(other) @@ -118,13 +120,13 @@ class Project < ActiveRecord::Base def fullname name end - + def branch if project? || module? s=kee.split(':') if s.size>=3 return s[2] - end + end end nil end @@ -156,19 +158,19 @@ class Project < ActiveRecord::Base # when regular active record impl return string typed objects if results.first[date_column_name].class == Time results.each do |hash| - chart_measures << ChartMeasure.new( hash[date_column_name], hash[value_column_name] ) + chart_measures << ChartMeasure.new(hash[date_column_name], hash[value_column_name]) end else results.each do |hash| - chart_measures << ChartMeasure.new( Time.parse( hash[date_column_name] ), hash[value_column_name].to_d ) + chart_measures << ChartMeasure.new(Time.parse(hash[date_column_name]), hash[value_column_name].to_d) end end end chart_measures end - + def parent_module(current_module) current_module.root ? parent_module(current_module.root) : current_module end - + end -- cgit v1.2.3