summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsimonbrandhof <simon.brandhof@gmail.com>2010-09-14 13:01:22 +0000
committersimonbrandhof <simon.brandhof@gmail.com>2010-09-14 13:01:22 +0000
commit42c3d47753e93dd92d2caf214df1f4db01d3b27b (patch)
treea6e18b0f6d5eb939026b3d5e1363bab1f9c353a2
parentddcc6272a62c245618d7797712062c96ff7ad3d4 (diff)
downloadsonarqube-42c3d47753e93dd92d2caf214df1f4db01d3b27b.tar.gz
sonarqube-42c3d47753e93dd92d2caf214df1f4db01d3b27b.zip
backward compatibility of ConfigurationImportable rule repositories
-rw-r--r--sonar-server/src/main/java/org/sonar/server/platform/Platform.java1
-rw-r--r--sonar-server/src/main/java/org/sonar/server/rules/DeprecatedProfileImporters.java93
-rw-r--r--sonar-server/src/main/java/org/sonar/server/rules/ProfilesConsole.java42
-rw-r--r--sonar-server/src/main/webapp/WEB-INF/app/controllers/profiles_controller.rb2
4 files changed, 123 insertions, 15 deletions
diff --git a/sonar-server/src/main/java/org/sonar/server/platform/Platform.java b/sonar-server/src/main/java/org/sonar/server/platform/Platform.java
index aec1073f6b5..5bbb113f777 100644
--- a/sonar-server/src/main/java/org/sonar/server/platform/Platform.java
+++ b/sonar-server/src/main/java/org/sonar/server/platform/Platform.java
@@ -177,6 +177,7 @@ public final class Platform {
servicesContainer.as(Characteristics.CACHE).addComponent(DeprecatedRuleRepositories.class);
servicesContainer.as(Characteristics.CACHE).addComponent(DeprecatedProfiles.class);
servicesContainer.as(Characteristics.CACHE).addComponent(DeprecatedProfileExporters.class);
+ servicesContainer.as(Characteristics.CACHE).addComponent(DeprecatedProfileImporters.class);
servicesContainer.as(Characteristics.CACHE).addComponent(ProfilesConsole.class);
servicesContainer.as(Characteristics.CACHE).addComponent(RulesConsole.class);
diff --git a/sonar-server/src/main/java/org/sonar/server/rules/DeprecatedProfileImporters.java b/sonar-server/src/main/java/org/sonar/server/rules/DeprecatedProfileImporters.java
new file mode 100644
index 00000000000..c55ec758f1c
--- /dev/null
+++ b/sonar-server/src/main/java/org/sonar/server/rules/DeprecatedProfileImporters.java
@@ -0,0 +1,93 @@
+/*
+ * Sonar, open source software quality management tool.
+ * Copyright (C) 2009 SonarSource SA
+ * 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
+ */
+package org.sonar.server.rules;
+
+import org.apache.commons.io.IOUtils;
+import org.sonar.api.Plugin;
+import org.sonar.api.Plugins;
+import org.sonar.api.profiles.ProfileImporter;
+import org.sonar.api.profiles.RulesProfile;
+import org.sonar.api.rules.*;
+import org.sonar.api.utils.SonarException;
+import org.sonar.api.utils.ValidationMessages;
+
+import java.io.IOException;
+import java.io.Reader;
+import java.util.ArrayList;
+import java.util.List;
+
+public class DeprecatedProfileImporters {
+
+ private Plugins plugins;
+ private RuleFinder ruleFinder;
+ private RulesRepository[] deprecatedRepositories;
+
+ public DeprecatedProfileImporters(Plugins plugins, RuleFinder ruleFinder, RulesRepository[] deprecatedRepositories) {
+ this.deprecatedRepositories = deprecatedRepositories;
+ this.plugins = plugins;
+ this.ruleFinder = ruleFinder;
+ }
+
+ public DeprecatedProfileImporters(Plugins plugins, RuleFinder ruleFinder) {
+ this.deprecatedRepositories = new RulesRepository[0];
+ this.plugins = plugins;
+ this.ruleFinder = ruleFinder;
+ }
+
+ public List<ProfileImporter> create() {
+ List<ProfileImporter> result = new ArrayList<ProfileImporter>();
+ for (RulesRepository repo : deprecatedRepositories) {
+ if (repo instanceof ConfigurationImportable) {
+ result.add(new DeprecatedProfileImporter(getPlugin(repo), ruleFinder, repo));
+ }
+ }
+ return result;
+ }
+
+ private Plugin getPlugin(RulesRepository repository) {
+ return plugins.getPluginByExtension(repository);
+ }
+}
+
+class DeprecatedProfileImporter extends ProfileImporter {
+ private RulesRepository importableRepository;
+ private RuleFinder ruleFinder;
+
+ protected DeprecatedProfileImporter(Plugin plugin, RuleFinder ruleFinder, RulesRepository importableRepository) {
+ super(plugin.getKey(), plugin.getName());
+ this.importableRepository = importableRepository;
+ this.ruleFinder = ruleFinder;
+ setSupportedLanguages(importableRepository.getLanguage().getKey());
+ }
+
+ @Override
+ public RulesProfile importProfile(Reader reader, ValidationMessages messages) {
+ List<Rule> rules = new ArrayList<Rule>(ruleFinder.findAll(RuleQuery.create().withRepositoryKey(getKey())));
+ try {
+ RulesProfile profile = RulesProfile.create(getKey(), getName());
+ List<ActiveRule> activeRules = ((ConfigurationImportable) importableRepository).importConfiguration(IOUtils.toString(reader), rules);
+ profile.setActiveRules(activeRules);
+ return profile;
+
+ } catch (IOException e) {
+ throw new SonarException("Fail to load the profile definition", e);
+ }
+ }
+}
diff --git a/sonar-server/src/main/java/org/sonar/server/rules/ProfilesConsole.java b/sonar-server/src/main/java/org/sonar/server/rules/ProfilesConsole.java
index e538f7c80cf..64d525939bc 100644
--- a/sonar-server/src/main/java/org/sonar/server/rules/ProfilesConsole.java
+++ b/sonar-server/src/main/java/org/sonar/server/rules/ProfilesConsole.java
@@ -24,6 +24,8 @@ import org.apache.commons.lang.StringUtils;
import org.sonar.api.ServerComponent;
import org.sonar.api.database.DatabaseSession;
import org.sonar.api.profiles.*;
+import org.sonar.api.rules.ActiveRule;
+import org.sonar.api.rules.ActiveRuleParam;
import org.sonar.api.rules.RuleFinder;
import org.sonar.api.utils.ValidationMessages;
import org.sonar.jpa.session.DatabaseSessionFactory;
@@ -39,22 +41,29 @@ public final class ProfilesConsole implements ServerComponent {
private DatabaseSessionFactory sessionFactory;
private RuleFinder ruleFinder;
- private List<ProfileExporter> profileExporters = new ArrayList<ProfileExporter>();
- private List<ProfileImporter> profileImporters = new ArrayList<ProfileImporter>();
+ private List<ProfileExporter> exporters = new ArrayList<ProfileExporter>();
+ private List<ProfileImporter> importers = new ArrayList<ProfileImporter>();
public ProfilesConsole(DatabaseSessionFactory sessionFactory, RuleFinder ruleFinder,
ProfileExporter[] exporters, DeprecatedProfileExporters deprecatedExporters,
- ProfileImporter[] importers) {
+ ProfileImporter[] importers, DeprecatedProfileImporters deprecatedImporters) {
this.ruleFinder = ruleFinder;
this.sessionFactory = sessionFactory;
initProfileExporters(exporters, deprecatedExporters);
- this.profileImporters.addAll(Arrays.asList(importers));
+ initProfileImporters(importers, deprecatedImporters);
}
private void initProfileExporters(ProfileExporter[] exporters, DeprecatedProfileExporters deprecatedExporters) {
- this.profileExporters.addAll(Arrays.asList(exporters));
+ this.exporters.addAll(Arrays.asList(exporters));
for (ProfileExporter exporter : deprecatedExporters.create()) {
- this.profileExporters.add(exporter);
+ this.exporters.add(exporter);
+ }
+ }
+
+ private void initProfileImporters(ProfileImporter[] importers, DeprecatedProfileImporters deprecatedImporters) {
+ this.importers.addAll(Arrays.asList(importers));
+ for (ProfileImporter importer : deprecatedImporters.create()) {
+ this.importers.add(importer);
}
}
@@ -91,7 +100,7 @@ public final class ProfilesConsole implements ServerComponent {
public List<ProfileExporter> getProfileExportersForLanguage(String language) {
List<ProfileExporter> result = new ArrayList<ProfileExporter>();
- for (ProfileExporter exporter : profileExporters) {
+ for (ProfileExporter exporter : exporters) {
if (exporter.getSupportedLanguages() == null || exporter.getSupportedLanguages().length == 0 || ArrayUtils.contains(exporter.getSupportedLanguages(), language)) {
result.add(exporter);
}
@@ -101,7 +110,7 @@ public final class ProfilesConsole implements ServerComponent {
public List<ProfileImporter> getProfileImportersForLanguage(String language) {
List<ProfileImporter> result = new ArrayList<ProfileImporter>();
- for (ProfileImporter importer : profileImporters) {
+ for (ProfileImporter importer : importers) {
if (importer.getSupportedLanguages() == null || importer.getSupportedLanguages().length == 0 || ArrayUtils.contains(importer.getSupportedLanguages(), language)) {
result.add(importer);
}
@@ -122,24 +131,29 @@ public final class ProfilesConsole implements ServerComponent {
}
/**
- * Important : the ruby controller has already removed existing profile with same name/language.
+ * Important : the ruby controller has already create the profile
*/
public ValidationMessages importProfile(String profileName, String language, String importerKey, String profileDefinition) {
ValidationMessages messages = ValidationMessages.create();
ProfileImporter importer = getProfileImporter(importerKey);
RulesProfile profile = importer.importProfile(new StringReader(profileDefinition), messages);
if (!messages.hasErrors()) {
- profile.setName(profileName);
- profile.setLanguage(language);
DatabaseSession session = sessionFactory.getSession();
- session.saveWithoutFlush(profile);
+ RulesProfile persistedProfile = session.getSingleResult(RulesProfile.class, "name", profileName, "language", language);
+ for (ActiveRule activeRule : profile.getActiveRules()) {
+ ActiveRule persistedActiveRule = persistedProfile.activateRule(activeRule.getRule(), activeRule.getPriority());
+ for (ActiveRuleParam activeRuleParam : activeRule.getActiveRuleParams()) {
+ persistedActiveRule.setParameter(activeRuleParam.getKey(), activeRuleParam.getValue());
+ }
+ }
+ session.saveWithoutFlush(persistedProfile);
session.commit();
}
return messages;
}
public ProfileExporter getProfileExporter(String exporterKey) {
- for (ProfileExporter exporter : profileExporters) {
+ for (ProfileExporter exporter : exporters) {
if (StringUtils.equals(exporterKey, exporter.getKey())) {
return exporter;
}
@@ -148,7 +162,7 @@ public final class ProfilesConsole implements ServerComponent {
}
public ProfileImporter getProfileImporter(String exporterKey) {
- for (ProfileImporter importer : profileImporters) {
+ for (ProfileImporter importer : importers) {
if (StringUtils.equals(exporterKey, importer.getKey())) {
return importer;
}
diff --git a/sonar-server/src/main/webapp/WEB-INF/app/controllers/profiles_controller.rb b/sonar-server/src/main/webapp/WEB-INF/app/controllers/profiles_controller.rb
index 50e9f6b27e2..0e097d5ef7f 100644
--- a/sonar-server/src/main/webapp/WEB-INF/app/controllers/profiles_controller.rb
+++ b/sonar-server/src/main/webapp/WEB-INF/app/controllers/profiles_controller.rb
@@ -65,7 +65,7 @@ class ProfilesController < ApplicationController
if ok && params[:backup]
params[:backup].each_pair do |importer_key, file|
if !file.blank? && ok
- messages = java_facade.importProfile(profile.id, importer_key, read_file_param(file))
+ messages = java_facade.importProfile(profile_name, language, importer_key, read_file_param(file))
flash_validation_messages(messages)
ok &= !messages.hasErrors()
end