summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@gmail.com>2012-11-26 17:27:58 +0100
committerSimon Brandhof <simon.brandhof@gmail.com>2012-11-26 17:27:58 +0100
commit1ac7e40d2210a59f3650d3c1d5a394afdbe09e45 (patch)
tree59e2e941670f7061b5728974b53f7fcd2838fdc8
parent83f1a6be23cc239d4d3790e57ff1fa24306a0a82 (diff)
downloadsonarqube-1ac7e40d2210a59f3650d3c1d5a394afdbe09e45.tar.gz
sonarqube-1ac7e40d2210a59f3650d3c1d5a394afdbe09e45.zip
SONAR-3825 manage system filters
-rw-r--r--plugins/sonar-core-plugin/src/main/resources/org/sonar/l10n/core.properties9
-rw-r--r--sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl1
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/controllers/measures_controller.rb4
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/controllers/system_measure_filters_controller.rb61
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/models/measure_filter.rb2
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb2
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/measures/manage.html.erb8
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/measures/search.html.erb11
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/views/system_measure_filters/index.html.erb71
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/db/migrate/356_create_measure_filters.rb1
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/db/migrate/357_move_existing_measure_filters.rb3
11 files changed, 164 insertions, 9 deletions
diff --git a/plugins/sonar-core-plugin/src/main/resources/org/sonar/l10n/core.properties b/plugins/sonar-core-plugin/src/main/resources/org/sonar/l10n/core.properties
index a0a87406463..a21573326fc 100644
--- a/plugins/sonar-core-plugin/src/main/resources/org/sonar/l10n/core.properties
+++ b/plugins/sonar-core-plugin/src/main/resources/org/sonar/l10n/core.properties
@@ -353,6 +353,7 @@ resource_deletion.page={0} Deletion
update_key.page=Update Key
project_quality_profiles.page=Quality Profiles
bulk_deletion.page=Bulk Deletion
+system_measure_filters.page=System Measure Filters
# GWT pages
@@ -391,7 +392,13 @@ measure_filter.col.short_name=Name
measure_filter.col.version=Version
measure_filter.missing_name=Name is missing
measure_filter.name_too_long=Name is too long
-
+measure_filter.sharing=Sharing
+measure_filter.delete_confirm_title=Delete Filter
+measure_filter.are_you_sure_want_delete_filter_x=Are you sure that you want to delete the filter "{0}"?
+measure_filter.remove_from_system=Remove from system
+measure_filter.add_to_system=Add to system
+measure_filter.title_shared_filters=Shared Filters
+measure_filter.title_system_filters=System Filters
#------------------------------------------------------------------------------
#
diff --git a/sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl b/sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl
index 576451a88a2..ea4589cf455 100644
--- a/sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl
+++ b/sonar-core/src/main/resources/org/sonar/core/persistence/schema-h2.ddl
@@ -517,6 +517,7 @@ CREATE TABLE "SEMAPHORES" (
CREATE TABLE "MEASURE_FILTERS" (
"ID" INTEGER NOT NULL GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1),
"NAME" VARCHAR(100) NOT NULL,
+ "SYSTEM" BOOLEAN,
"SHARED" BOOLEAN NOT NULL DEFAULT FALSE,
"USER_ID" INTEGER,
"DESCRIPTION" VARCHAR(4000),
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/controllers/measures_controller.rb b/sonar-server/src/main/webapp/WEB-INF/app/controllers/measures_controller.rb
index 1b47de87cd9..6e4d283ff16 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/controllers/measures_controller.rb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/controllers/measures_controller.rb
@@ -87,8 +87,8 @@ class MeasuresController < ApplicationController
@shared_filters = MeasureFilter.find(:all,
:include => :user,
:conditions => ['shared=? and user_id<>?', true, current_user.id])
- @fav_filter_ids = current_user.measure_filter_favourites.map { |fav| fav.measure_filter_id }
Api::Utils.insensitive_sort!(@shared_filters) { |elt| elt.name }
+ @fav_filter_ids = current_user.measure_filter_favourites.map { |fav| fav.measure_filter_id }
end
# GET /measures/edit_form/<filter id>
@@ -183,7 +183,7 @@ class MeasuresController < ApplicationController
end
def owner?(filter)
- current_user && filter.user_id==current_user.id
+ current_user && (filter.user_id==current_user.id || (filter.user_id==nil && has_role?(:admin)))
end
end
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/controllers/system_measure_filters_controller.rb b/sonar-server/src/main/webapp/WEB-INF/app/controllers/system_measure_filters_controller.rb
new file mode 100644
index 00000000000..43cebd75465
--- /dev/null
+++ b/sonar-server/src/main/webapp/WEB-INF/app/controllers/system_measure_filters_controller.rb
@@ -0,0 +1,61 @@
+#
+# Sonar, open source software quality management tool.
+# Copyright (C) 2008-2012 SonarSource
+# mailto:contact AT sonarsource DOT com
+#
+# Sonar is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 3 of the License, or (at your option) any later version.
+#
+# Sonar 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
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with Sonar; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
+#
+class SystemMeasureFiltersController < ApplicationController
+ SECTION = Navigation::SECTION_CONFIGURATION
+
+ # GET /system_measure_filters/index
+ def index
+ access_denied unless has_role?(:admin)
+
+ @system_filters = MeasureFilter.find(:all, :include => :user, :conditions => ['system=?', true])
+ Api::Utils.insensitive_sort!(@system_filters) { |f| f.name }
+
+ @shared_filters = MeasureFilter.find(:all, :include => :user, :conditions => ['shared=? and system=?', true, false])
+ end
+
+ # POST /system_measure_filters/add/<filter id>
+ def add
+ verify_post_request
+ access_denied unless has_role?(:admin)
+ require_parameters :id
+
+ filter = MeasureFilter.find(params[:id])
+ filter.system=true
+ unless filter.save
+ flash[:error]=filter.errors.full_messages.join("<br/>")
+ end
+ redirect_to :action => :index
+ end
+
+ # POST /system_measure_filters/remove/<filter id>
+ def remove
+ verify_post_request
+ access_denied unless has_role?(:admin)
+ require_parameters :id
+
+ filter = MeasureFilter.find(params[:id])
+ filter.system=false
+ unless filter.save
+ flash[:error]=filter.errors.full_messages.join("<br/>")
+ end
+ redirect_to :action => :index
+ end
+
+end
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/models/measure_filter.rb b/sonar-server/src/main/webapp/WEB-INF/app/models/measure_filter.rb
index 984ecc84b78..cc5e50dc5b2 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/models/measure_filter.rb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/models/measure_filter.rb
@@ -362,5 +362,7 @@ class MeasureFilter < ActiveRecord::Base
count = MeasureFilter.count('id', :conditions => ['name=? and shared=? and user_id!=?', name, true, user_id])
errors.add_to_base('Other users already shared filters with the same name') if count>0
end
+
+ errors.add_to_base('Only shared filters can be flagged as system filter') if system && !shared
end
end \ No newline at end of file
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb
index cc5851e7536..0ab7c92f1a9 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/layouts/_layout.html.erb
@@ -147,6 +147,8 @@
<a href="<%= ApplicationController.root_context -%>/manual_rules/index"><%= message('manual_rules.page') -%></a></li>
<li class="<%= 'selected' if controller.controller_path=='admin_dashboards' -%>">
<a href="<%= ApplicationController.root_context -%>/admin_dashboards/index"><%= message('default_dashboards.page') -%></a></li>
+ <li class="<%= 'selected' if controller.controller_path=='system_measure_filters' -%>">
+ <a href="<%= ApplicationController.root_context -%>/system_measure_filters"><%= message('system_measure_filters.page') -%></a></li>
<% controller.java_facade.getPages(Navigation::SECTION_CONFIGURATION, nil, nil, nil, nil).each do |page|
page_url = (page.isController() ? page.getId() : "/plugins/configuration/#{page.getId()}")
%>
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/measures/manage.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/measures/manage.html.erb
index 48e5a3fc889..a5b6f5ddd2e 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/measures/manage.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/measures/manage.html.erb
@@ -29,7 +29,7 @@
<tr>
<th class="thin"></th>
<th><%= message('name') -%></th>
- <th><%= message('sharing') -%></th>
+ <th><%= message('measure_filter.sharing') -%></th>
<th class="right"><%= message('operations') -%></th>
</tr>
</thead>
@@ -66,8 +66,8 @@
:class => 'link-action link-red',
:id => "delete_#{filter.name.parameterize}",
:confirm_button => message('delete'),
- :confirm_title => 'measure_filters.delete_confirm_title',
- :confirm_msg => 'measure_filters.are_you_sure_want_delete_filter_x',
+ :confirm_title => 'measure_filter.delete_confirm_title',
+ :confirm_msg => 'measure_filter.are_you_sure_want_delete_filter_x',
:confirm_msg_params => [filter.name] -%>
</td>
</tr>
@@ -106,7 +106,7 @@
<% end %>
</td>
<td>
- <%= h filter.user.name -%>
+ <%= filter.user ? h(filter.user.name) : '-' -%>
</td>
<td class="thin nowrap right">
<a id="copy-<%= filter.name.parameterize -%>" href="<%= ApplicationController.root_context -%>/measures/copy_form/<%= filter.id -%>" class="link-action open-modal"><%= message('copy') -%></a>
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/measures/search.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/measures/search.html.erb
index e27ee1e0307..5e9fe5f1be1 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/views/measures/search.html.erb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/measures/search.html.erb
@@ -106,9 +106,18 @@
</table>
</form>
+ <br/>
+ <ul id="system-filters">
+ <% MeasureFilter.find(:all, :select => ['id,name'], :conditions => ['system=?', true]).each do |system_filter| %>
+ <li>
+ <a href="<%= ApplicationController.root_context -%>/measures/filter/<%= system_filter.id -%>"><%= h system_filter.name -%></a>
+ </li>
+ <% end %>
+ </ul>
+
<% if logged_in? %>
<br/>
- <ul id="my-filters">
+ <ul id="fav-filters">
<% current_user.favourited_measure_filters.each do |my_filter| %>
<li>
<a href="<%= ApplicationController.root_context -%>/measures/filter/<%= my_filter.id -%>"><%= h my_filter.name -%></a>
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/views/system_measure_filters/index.html.erb b/sonar-server/src/main/webapp/WEB-INF/app/views/system_measure_filters/index.html.erb
new file mode 100644
index 00000000000..bb87a5bc4a4
--- /dev/null
+++ b/sonar-server/src/main/webapp/WEB-INF/app/views/system_measure_filters/index.html.erb
@@ -0,0 +1,71 @@
+<h2><%= h message('measure_filter.title_system_filters') %></h2>
+<table class="data marginbottom10" id="system-filters">
+ <thead>
+ <tr>
+ <th><%= message('name') -%></th>
+ <th><%= message('shared_by') -%></th>
+ <th class="right"><%= message('operations') -%></th>
+ </tr>
+ </thead>
+ <tbody>
+ <% if @system_filters.empty? %>
+ <tr class="even">
+ <td colspan="3"><%= message('filters.no_filters') -%></td>
+ </tr>
+ <% else %>
+ <% @system_filters.each do |filter| %>
+ <tr id="system-<%= filter.name.parameterize -%>" class="<%= cycle('even', 'odd', :name => 'system-filters') -%>">
+ <td>
+ <%= link_to h(filter.name), :action => 'filter', :id => filter.id -%>
+ <% if filter.description %>
+ <div><%= h filter.description -%></div>
+ <% end %>
+ </td>
+ <td>
+ <%= filter.user ? h(filter.user.name) : '-' -%>
+ </td>
+ <td class="thin nowrap right">
+ <%= link_to message('measure_filter.remove_from_system'), {:action => :remove, :id => filter.id}, {:class => 'button', :method => :post} -%>
+ </td>
+ </tr>
+ <% end %>
+ <% end %>
+ </tbody>
+</table>
+
+<br/>
+
+<h2><%= h message('measure_filter.title_shared_filters') %></h2>
+<table class="data" id="shared-filters">
+ <thead>
+ <tr>
+ <th><%= message('name') -%></th>
+ <th><%= message('shared_by') -%></th>
+ <th class="right"><%= message('operations') -%></th>
+ </tr>
+ </thead>
+ <tbody>
+ <% if @shared_filters.empty? %>
+ <tr class="even">
+ <td colspan="4"><%= message('filters.no_filters') -%></td>
+ </tr>
+ <% else %>
+ <% @shared_filters.each do |filter| %>
+ <tr id="shared-<%= filter.name.parameterize -%>" class="<%= cycle('even', 'odd', :name => 'shared-filters') -%>">
+ <td>
+ <%= link_to h(filter.name), :action => 'filter', :id => filter.id -%>
+ <% if filter.description %>
+ <div><%= h filter.description -%></div>
+ <% end %>
+ </td>
+ <td>
+ <%= filter.user ? h(filter.user.name) : '-' -%>
+ </td>
+ <td class="thin nowrap right">
+ <%= link_to message('measure_filter.add_to_system'), {:action => :add, :id => filter.id}, {:class => 'button', :method => :post} -%>
+ </td>
+ </tr>
+ <% end %>
+ <% end %>
+ </tbody>
+</table>
diff --git a/sonar-server/src/main/webapp/WEB-INF/db/migrate/356_create_measure_filters.rb b/sonar-server/src/main/webapp/WEB-INF/db/migrate/356_create_measure_filters.rb
index 30f5210435a..b7066509f5f 100644
--- a/sonar-server/src/main/webapp/WEB-INF/db/migrate/356_create_measure_filters.rb
+++ b/sonar-server/src/main/webapp/WEB-INF/db/migrate/356_create_measure_filters.rb
@@ -27,6 +27,7 @@ class CreateMeasureFilters < ActiveRecord::Migration
t.column 'name', :string, :null => false, :limit => 100
t.column 'user_id', :integer, :null => true
t.column 'shared', :boolean, :default => false, :null => false
+ t.column 'system', :boolean
t.column 'description', :string, :null => true, :limit => 4000
t.column 'data', :text, :null => true
t.timestamps
diff --git a/sonar-server/src/main/webapp/WEB-INF/db/migrate/357_move_existing_measure_filters.rb b/sonar-server/src/main/webapp/WEB-INF/db/migrate/357_move_existing_measure_filters.rb
index f0b4b836f90..a1a5b1b8f53 100644
--- a/sonar-server/src/main/webapp/WEB-INF/db/migrate/357_move_existing_measure_filters.rb
+++ b/sonar-server/src/main/webapp/WEB-INF/db/migrate/357_move_existing_measure_filters.rb
@@ -57,7 +57,8 @@ class MoveExistingMeasureFilters < ActiveRecord::Migration
new_filter = MeasureFilter.new
new_filter.name = old_filter.name
new_filter.user_id = old_filter.user_id
- new_filter.shared = old_filter.shared
+ new_filter.system = old_filter.user_id.nil?
+ new_filter.shared = (old_filter.shared || old_filter.user_id.nil?)
data = []
data << 'onFavourites=true' if old_filter.favourites
if old_filter.resource_id