aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-server/src/main/java/org/sonar/server/rule2/RuleNormalizer.java104
1 files changed, 58 insertions, 46 deletions
diff --git a/sonar-server/src/main/java/org/sonar/server/rule2/RuleNormalizer.java b/sonar-server/src/main/java/org/sonar/server/rule2/RuleNormalizer.java
index 941b8d7ddfc..5aa1ec9500a 100644
--- a/sonar-server/src/main/java/org/sonar/server/rule2/RuleNormalizer.java
+++ b/sonar-server/src/main/java/org/sonar/server/rule2/RuleNormalizer.java
@@ -29,8 +29,6 @@ import org.sonar.core.rule.RuleRuleTagDto;
import org.sonar.core.rule.RuleTagType;
import org.sonar.server.search.BaseNormalizer;
-import java.io.IOException;
-
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
public class RuleNormalizer extends BaseNormalizer<RuleDto, RuleKey> {
@@ -92,70 +90,84 @@ public class RuleNormalizer extends BaseNormalizer<RuleDto, RuleKey> {
}
}
- public RuleNormalizer(RuleDao ruleDao){
+ public RuleNormalizer(RuleDao ruleDao) {
this.ruleDao = ruleDao;
}
@Override
- public UpdateRequest normalize(RuleKey key) throws IOException {
+ public UpdateRequest normalize(RuleKey key) {
return normalize(ruleDao.getByKey(key));
}
@Override
- public UpdateRequest normalize(RuleDto rule) throws IOException {
- XContentBuilder document = jsonBuilder().startObject();
- indexField(RuleField.KEY.key(), rule.getRuleKey(), document);
- indexField(RuleField.REPOSITORY.key(), rule.getRepositoryKey(), document);
- indexField(RuleField.NAME.key(), rule.getName(), document);
- indexField(RuleField.CREATED_AT.key(), rule.getCreatedAt(), document);
- indexField(RuleField.UPDATED_AT.key(), rule.getUpdatedAt(), document);
- indexField(RuleField.HTML_DESCRIPTION.key(), rule.getDescription(), document);
- indexField(RuleField.SEVERITY.key(), rule.getSeverityString(), document);
- indexField(RuleField.STATUS.key(), rule.getStatus(), document);
- indexField(RuleField.LANGUAGE.key(), rule.getLanguage(), document);
- indexField(RuleField.INTERNAL_KEY.key(), rule.getConfigKey(), document);
- indexField(RuleField.TEMPLATE.key(), rule.getCardinality() == Cardinality.MULTIPLE, document);
-
- document.startArray(RuleField.TAGS.key()).endArray();
- document.startArray(RuleField.SYSTEM_TAGS.key()).endArray();
- document.startObject(RuleField.PARAMS.key()).endObject();
- document.startObject(RuleField.ACTIVE.key()).endObject();
+ public UpdateRequest normalize(RuleDto rule) {
+ try {
+ XContentBuilder document = jsonBuilder().startObject();
+ indexField(RuleField.KEY.key(), rule.getRuleKey(), document);
+ indexField(RuleField.REPOSITORY.key(), rule.getRepositoryKey(), document);
+ indexField(RuleField.NAME.key(), rule.getName(), document);
+ indexField(RuleField.CREATED_AT.key(), rule.getCreatedAt(), document);
+ indexField(RuleField.UPDATED_AT.key(), rule.getUpdatedAt(), document);
+ indexField(RuleField.HTML_DESCRIPTION.key(), rule.getDescription(), document);
+ indexField(RuleField.SEVERITY.key(), rule.getSeverityString(), document);
+ indexField(RuleField.STATUS.key(), rule.getStatus(), document);
+ indexField(RuleField.LANGUAGE.key(), rule.getLanguage(), document);
+ indexField(RuleField.INTERNAL_KEY.key(), rule.getConfigKey(), document);
+ indexField(RuleField.TEMPLATE.key(), rule.getCardinality() == Cardinality.MULTIPLE, document);
+
+ document.startArray(RuleField.TAGS.key()).endArray();
+ document.startArray(RuleField.SYSTEM_TAGS.key()).endArray();
+ document.startObject(RuleField.PARAMS.key()).endObject();
+ document.startObject(RuleField.ACTIVE.key()).endObject();
/* Done normalizing for Rule */
- document.endObject();
+ document.endObject();
/* Creating updateRequest */
- UpdateRequest request = new UpdateRequest().doc(document);
- request.docAsUpsert(true);
- return request;
+ UpdateRequest request = new UpdateRequest().doc(document);
+ request.docAsUpsert(true);
+ return request;
+ } catch (Exception e) {
+ throw new IllegalStateException(String.format("Could not normalize RuleDto with key %s", rule.getKey().toString()), e);
+ }
}
- public UpdateRequest normalize(RuleParamDto param, RuleKey key) throws IOException {
+ public UpdateRequest normalize(RuleParamDto param, RuleKey key) {
+ try {
/* Normalize the params */
- XContentBuilder document = jsonBuilder().startObject();
- document.startObject(RuleField.PARAMS.key());
- document.startObject(param.getName());
- indexField(RuleParamField.NAME.key(), param.getName(), document);
- indexField(RuleParamField.TYPE.key(), param.getType(), document);
- indexField(RuleParamField.DESCRIPTION.key(), param.getDescription(), document);
- indexField(RuleParamField.DEFAULT_VALUE.key(), param.getDefaultValue(), document);
- document.endObject();
- document.endObject();
+ XContentBuilder document = jsonBuilder().startObject();
+ document.startObject(RuleField.PARAMS.key());
+ document.startObject(param.getName());
+ indexField(RuleParamField.NAME.key(), param.getName(), document);
+ indexField(RuleParamField.TYPE.key(), param.getType(), document);
+ indexField(RuleParamField.DESCRIPTION.key(), param.getDescription(), document);
+ indexField(RuleParamField.DEFAULT_VALUE.key(), param.getDefaultValue(), document);
+ document.endObject();
+ document.endObject();
/* Creating updateRequest */
- UpdateRequest request = new UpdateRequest().doc(document);
- request.docAsUpsert(true);
- return request;
+ UpdateRequest request = new UpdateRequest().doc(document);
+ request.docAsUpsert(true);
+ return request;
+ } catch (Exception e) {
+ throw new IllegalStateException(String.format("Could not normalize Object (%s) for key %s",
+ param.getClass().getSimpleName(), key.toString()), e);
+ }
}
- public UpdateRequest normalize(RuleRuleTagDto tag, RuleKey key) throws IOException {
- String field = RuleField.TAGS.key();
- if(tag.getType().equals(RuleTagType.SYSTEM)){
- field = RuleField.SYSTEM_TAGS.key();
+ public UpdateRequest normalize(RuleRuleTagDto tag, RuleKey key) {
+ try {
+ String field = RuleField.TAGS.key();
+ if (tag.getType().equals(RuleTagType.SYSTEM)) {
+ field = RuleField.SYSTEM_TAGS.key();
+ }
+ return new UpdateRequest()
+ .script("ctx._source." + field + " += tag")
+ .addScriptParam("tag", tag.getTag());
+ } catch (Exception e) {
+ throw new IllegalStateException(String.format("Could not normalize Object (%s) for key %s",
+ tag.getClass().getSimpleName(), key.toString()), e);
}
- return new UpdateRequest()
- .script("ctx._source."+field+" += tag")
- .addScriptParam("tag",tag.getTag());
}
}