Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* SonarQube
* Copyright (C) 2009-2021 SonarSource SA
* mailto:info AT sonarsource DOT com
*
* This program 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.
*
* 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser 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.
*/
package org.sonar.api.server.profile;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import javax.annotation.CheckForNull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.Immutable;
import org.sonar.api.ExtensionPoint;
import org.sonar.api.rule.RuleKey;
import org.sonar.api.rule.Severity;
import org.sonar.api.server.ServerSide;
import static java.lang.String.format;
import static java.util.Collections.unmodifiableList;
import static java.util.Collections.unmodifiableMap;
import static org.apache.commons.lang.StringUtils.defaultIfEmpty;
import static org.apache.commons.lang.StringUtils.isNotBlank;
import static org.sonar.api.utils.Preconditions.checkArgument;
/**
* Define built-in quality profiles which are automatically registered during SonarQube startup.
* We no more provide any facility to load profiles from XML file or annotated classes, but it should
* be straightforward to implement (adapt code of deprecated {@link org.sonar.api.profiles.AnnotationProfileParser}
* or {@link org.sonar.api.profiles.XMLProfileParser} for example).
*
* @since 6.6
*/
@ServerSide
@ExtensionPoint
public interface BuiltInQualityProfilesDefinition {
/**
* Instantiated by core but not by plugins, except for their tests.
*/
class Context {
private final Map> profilesByLanguageAndName = new HashMap<>();
/**
* New builder for {@link BuiltInQualityProfile}.
*
* A plugin can activate rules in a built in quality profile that is defined by another plugin.
*/
public NewBuiltInQualityProfile createBuiltInQualityProfile(String name, String language) {
return new NewBuiltInQualityProfileImpl(this, name, language);
}
private void registerProfile(NewBuiltInQualityProfileImpl newProfile) {
String language = newProfile.language();
String name = newProfile.name();
checkArgument(!profilesByLanguageAndName.computeIfAbsent(language, l -> new LinkedHashMap<>()).containsKey(name),
"There is already a quality profile with name '%s' for language '%s'", name, language);
profilesByLanguageAndName.get(language).put(name, new BuiltInQualityProfileImpl(newProfile));
}
public Map> profilesByLanguageAndName() {
return profilesByLanguageAndName;
}
public BuiltInQualityProfile profile(String language, String name) {
return profilesByLanguageAndName.computeIfAbsent(language, l -> new LinkedHashMap<>()).get(name);
}
}
interface NewBuiltInQualityProfile {
/**
* Set whether this is the default profile for the language. The default profile is used when none is explicitly defined when analyzing a project.
*/
NewBuiltInQualityProfile setDefault(boolean value);
/**
* Activate a rule with specified key.
*
* @throws IllegalArgumentException if rule is already activated in this profile.
*/
NewBuiltInActiveRule activateRule(String repoKey, String ruleKey);
Collection activeRules();
String language();
String name();
boolean isDefault();
void done();
}
class NewBuiltInQualityProfileImpl implements NewBuiltInQualityProfile {
private final Context context;
private final String name;
private final String language;
private boolean isDefault;
private final Map newActiveRules = new HashMap<>();
private NewBuiltInQualityProfileImpl(Context context, String name, String language) {
this.context = context;
this.name = name;
this.language = language;
}
@Override
public NewBuiltInQualityProfile setDefault(boolean value) {
this.isDefault = value;
return this;
}
@Override
public NewBuiltInActiveRule activateRule(String repoKey, String ruleKey) {
RuleKey ruleKeyObj = RuleKey.of(repoKey, ruleKey);
checkArgument(!newActiveRules.containsKey(ruleKeyObj), "The rule '%s' is already activated", ruleKeyObj);
NewBuiltInActiveRule newActiveRule = new NewBuiltInActiveRule(repoKey, ruleKey);
newActiveRules.put(ruleKeyObj, newActiveRule);
return newActiveRule;
}
@Override
public String language() {
return language;
}
@Override
public String name() {
return name;
}
@Override
public boolean isDefault() {
return isDefault;
}
@Override
public Collection activeRules() {
return newActiveRules.values();
}
@Override
public void done() {
checkArgument(isNotBlank(name), "Built-In Quality Profile can't have a blank name");
checkArgument(isNotBlank(language), "Built-In Quality Profile can't have a blank language");
context.registerProfile(this);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder("NewBuiltInQualityProfile{");
sb.append("name='").append(name).append('\'');
sb.append(", language='").append(language).append('\'');
sb.append(", default='").append(isDefault).append('\'');
sb.append('}');
return sb.toString();
}
}
interface BuiltInQualityProfile {
String name();
String language();
boolean isDefault();
@CheckForNull
BuiltInActiveRule rule(RuleKey ruleKey);
List rules();
}
@Immutable
class BuiltInQualityProfileImpl implements BuiltInQualityProfile {
private final String language;
private final String name;
private final boolean isDefault;
private final Map activeRulesByKey;
private BuiltInQualityProfileImpl(NewBuiltInQualityProfileImpl newProfile) {
this.name = newProfile.name();
this.language = newProfile.language();
this.isDefault = newProfile.isDefault();
Map ruleBuilder = new HashMap<>();
for (NewBuiltInActiveRule newActiveRule : newProfile.activeRules()) {
ruleBuilder.put(RuleKey.of(newActiveRule.repoKey, newActiveRule.ruleKey), new BuiltInActiveRule(newActiveRule));
}
this.activeRulesByKey = unmodifiableMap(ruleBuilder);
}
@Override
public String language() {
return language;
}
@Override
public String name() {
return name;
}
@Override
public boolean isDefault() {
return isDefault;
}
@Override
@CheckForNull
public BuiltInActiveRule rule(RuleKey ruleKey) {
return activeRulesByKey.get(ruleKey);
}
@Override
public List rules() {
return unmodifiableList(new ArrayList<>(activeRulesByKey.values()));
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
BuiltInQualityProfileImpl that = (BuiltInQualityProfileImpl) o;
return language.equals(that.language) && name.equals(that.name);
}
@Override
public int hashCode() {
int result = name.hashCode();
result = 31 * result + language.hashCode();
return result;
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder("BuiltInQualityProfile{");
sb.append("name='").append(name).append('\'');
sb.append(", language='").append(language).append('\'');
sb.append(", default='").append(isDefault).append('\'');
sb.append('}');
return sb.toString();
}
}
class NewBuiltInActiveRule {
private final String repoKey;
private final String ruleKey;
private String overriddenSeverity = null;
private final Map paramsByKey = new HashMap<>();
private NewBuiltInActiveRule(String repoKey, String ruleKey) {
this.repoKey = repoKey;
this.ruleKey = ruleKey;
}
public String repoKey() {
return this.repoKey;
}
public String ruleKey() {
return this.ruleKey;
}
/**
* Override default rule severity in this quality profile. By default the active rule will have the default rule severity.
*
* @param severity See {@link Severity} constants.
*/
public NewBuiltInActiveRule overrideSeverity(String severity) {
checkArgument(Severity.ALL.contains(severity), "Severity of rule %s is not correct: %s", RuleKey.of(repoKey, ruleKey), severity);
this.overriddenSeverity = severity;
return this;
}
/**
* Create a parameter with given unique key. Max length of key is 128 characters.
*/
public NewOverriddenParam overrideParam(String paramKey, @Nullable String value) {
checkArgument(!paramsByKey.containsKey(paramKey), "The parameter '%s' was already overridden on the built in active rule %s", paramKey, this);
NewOverriddenParam param = new NewOverriddenParam(paramKey).setOverriddenValue(value);
paramsByKey.put(paramKey, param);
return param;
}
public Collection getOverriddenParams() {
return paramsByKey.values();
}
@Override
public String toString() {
return format("[repository=%s, key=%s]", repoKey, ruleKey);
}
}
/**
* A rule activated on a built in quality profile.
*/
@Immutable
class BuiltInActiveRule {
private final String repoKey;
private final String ruleKey;
private final String overriddenSeverity;
private final Map overriddenParams;
private BuiltInActiveRule(NewBuiltInActiveRule newBuiltInActiveRule) {
this.repoKey = newBuiltInActiveRule.repoKey();
this.ruleKey = newBuiltInActiveRule.ruleKey();
this.overriddenSeverity = newBuiltInActiveRule.overriddenSeverity;
Map paramsBuilder = new HashMap<>();
for (NewOverriddenParam newParam : newBuiltInActiveRule.getOverriddenParams()) {
paramsBuilder.put(newParam.key, new OverriddenParam(newParam));
}
this.overriddenParams = Collections.unmodifiableMap(paramsBuilder);
}
public String repoKey() {
return repoKey;
}
public String ruleKey() {
return ruleKey;
}
@CheckForNull
public String overriddenSeverity() {
return overriddenSeverity;
}
@CheckForNull
public OverriddenParam overriddenParam(String key) {
return overriddenParams.get(key);
}
public List overriddenParams() {
return unmodifiableList(new ArrayList<>(overriddenParams.values()));
}
@Override
public String toString() {
return format("[repository=%s, key=%s]", repoKey, ruleKey);
}
}
class NewOverriddenParam {
private final String key;
private String overriddenValue;
private NewOverriddenParam(String key) {
this.key = key;
}
public String key() {
return key;
}
/**
* Empty default value will be converted to null. Max length is 4000 characters.
*/
public NewOverriddenParam setOverriddenValue(@Nullable String s) {
this.overriddenValue = defaultIfEmpty(s, null);
return this;
}
}
@Immutable
class OverriddenParam {
private final String key;
private final String overriddenValue;
private OverriddenParam(NewOverriddenParam newOverriddenParam) {
this.key = newOverriddenParam.key();
this.overriddenValue = newOverriddenParam.overriddenValue;
}
public String key() {
return key;
}
@Nullable
public String overriddenValue() {
return overriddenValue;
}
}
/**
* This method is executed when server is started.
*/
void define(Context context);
}