aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-db-migration
diff options
context:
space:
mode:
authorPierre <pierre.guillot@sonarsource.com>2022-05-20 15:38:30 +0200
committersonartech <sonartech@sonarsource.com>2022-05-24 20:10:14 +0000
commit99330585576462f5f823bade1ad69b6f7e919d25 (patch)
treedd0d74bc1bdaad99cc176b822c892c7e98d65a7a /server/sonar-db-migration
parent065455b4612697f9529e91a883ad74db2c2d8e6b (diff)
downloadsonarqube-99330585576462f5f823bade1ad69b6f7e919d25.tar.gz
sonarqube-99330585576462f5f823bade1ad69b6f7e919d25.zip
SONAR-16419 populate rules metadata columns from rules_metadata table
Diffstat (limited to 'server/sonar-db-migration')
-rw-r--r--server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/BooleanColumnDef.java4
-rw-r--r--server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/VarcharColumnDef.java4
-rw-r--r--server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v00/CreateInitialSchema.java622
-rw-r--r--server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/AddRulesMetadataColumnsToRulesTable.java98
-rw-r--r--server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/DbVersion95.java1
-rw-r--r--server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTable.java72
-rw-r--r--server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTableTest.java139
-rw-r--r--server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTableTest/schema.sql57
8 files changed, 625 insertions, 372 deletions
diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/BooleanColumnDef.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/BooleanColumnDef.java
index 9fdbcfe5d55..7047c64a96d 100644
--- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/BooleanColumnDef.java
+++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/BooleanColumnDef.java
@@ -43,6 +43,10 @@ public class BooleanColumnDef extends AbstractColumnDef {
return new Builder();
}
+ public static Builder newBooleanColumnDefBuilder(String column) {
+ return newBooleanColumnDefBuilder().setColumnName(column);
+ }
+
@Override
public String generateSqlType(Dialect dialect) {
switch (dialect.getId()) {
diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/VarcharColumnDef.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/VarcharColumnDef.java
index 56982a3f551..e0b18999014 100644
--- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/VarcharColumnDef.java
+++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/def/VarcharColumnDef.java
@@ -64,6 +64,10 @@ public class VarcharColumnDef extends AbstractColumnDef {
return new Builder();
}
+ public static Builder newVarcharColumnDefBuilder(String column) {
+ return newVarcharColumnDefBuilder().setColumnName(column);
+ }
+
public int getColumnSize() {
return columnSize;
}
diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v00/CreateInitialSchema.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v00/CreateInitialSchema.java
index f3ea9028e7a..6a31c40dc95 100644
--- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v00/CreateInitialSchema.java
+++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v00/CreateInitialSchema.java
@@ -166,13 +166,13 @@ public class CreateInitialSchema extends DdlChange {
private void createActiveRuleParameters(Context context) {
String tableName = "active_rule_parameters";
- VarcharColumnDef activeRuleUuidColumnDef = newVarcharColumnBuilder("active_rule_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef rulesParameterUuidColumnDef = newVarcharColumnBuilder("rules_parameter_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef activeRuleUuidColumnDef = newVarcharColumnDefBuilder("active_rule_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef rulesParameterUuidColumnDef = newVarcharColumnDefBuilder("rules_parameter_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder(VALUE_COL_NAME).setLimit(MAX_SIZE).build())
- .addColumn(newVarcharColumnBuilder("rules_parameter_key").setLimit(128).build())
+ .addColumn(newVarcharColumnDefBuilder(VALUE_COL_NAME).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("rules_parameter_key").setLimit(128).build())
.addColumn(activeRuleUuidColumnDef)
.addColumn(rulesParameterUuidColumnDef)
.build());
@@ -180,13 +180,13 @@ public class CreateInitialSchema extends DdlChange {
}
private void createActiveRules(Context context) {
- VarcharColumnDef profileUuidCol = newVarcharColumnBuilder("profile_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef ruleUuidCol = newVarcharColumnBuilder(RULE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef profileUuidCol = newVarcharColumnDefBuilder("profile_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef ruleUuidCol = newVarcharColumnDefBuilder(RULE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder("active_rules")
.addPkColumn(UUID_COL)
.addColumn(newIntegerColumnDefBuilder().setColumnName("failure_level").setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("inheritance").setLimit(10).build())
+ .addColumn(newVarcharColumnDefBuilder("inheritance").setLimit(10).build())
.addColumn(NULLABLE_TECHNICAL_CREATED_AT_COL)
.addColumn(NULLABLE_TECHNICAL_UPDATED_AT_COL)
.addColumn(profileUuidCol)
@@ -197,9 +197,9 @@ public class CreateInitialSchema extends DdlChange {
private void createAlmPats(Context context) {
String tableName = "alm_pats";
- VarcharColumnDef patCol = newVarcharColumnBuilder("pat").setIsNullable(false).setLimit(2000).build();
- VarcharColumnDef userUuidCol = newVarcharColumnBuilder(USER_UUID_COL_NAME).setIsNullable(false).setLimit(256).build();
- VarcharColumnDef almSettingUuidCol = newVarcharColumnBuilder("alm_setting_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef patCol = newVarcharColumnDefBuilder("pat").setIsNullable(false).setLimit(2000).build();
+ VarcharColumnDef userUuidCol = newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setIsNullable(false).setLimit(256).build();
+ VarcharColumnDef almSettingUuidCol = newVarcharColumnDefBuilder("alm_setting_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -214,32 +214,32 @@ public class CreateInitialSchema extends DdlChange {
private void createAlmSettings(Context context) {
String tableName = "alm_settings";
- VarcharColumnDef keeCol = newVarcharColumnBuilder("kee").setIsNullable(false).setLimit(200).build();
+ VarcharColumnDef keeCol = newVarcharColumnDefBuilder("kee").setIsNullable(false).setLimit(200).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("alm_id").setIsNullable(false).setLimit(UUID_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("alm_id").setIsNullable(false).setLimit(UUID_SIZE).build())
.addColumn(keeCol)
- .addColumn(newVarcharColumnBuilder("url").setIsNullable(true).setLimit(2000).build())
- .addColumn(newVarcharColumnBuilder("app_id").setIsNullable(true).setLimit(80).build())
- .addColumn(newVarcharColumnBuilder("private_key").setIsNullable(true).setLimit(2000).build())
- .addColumn(newVarcharColumnBuilder("pat").setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("url").setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("app_id").setIsNullable(true).setLimit(80).build())
+ .addColumn(newVarcharColumnDefBuilder("private_key").setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("pat").setIsNullable(true).setLimit(2000).build())
.addColumn(TECHNICAL_UPDATED_AT_COL)
.addColumn(TECHNICAL_CREATED_AT_COL)
- .addColumn(newVarcharColumnBuilder("client_id").setIsNullable(true).setLimit(80).build())
- .addColumn(newVarcharColumnBuilder("client_secret").setIsNullable(true).setLimit(80).build())
+ .addColumn(newVarcharColumnDefBuilder("client_id").setIsNullable(true).setLimit(80).build())
+ .addColumn(newVarcharColumnDefBuilder("client_secret").setIsNullable(true).setLimit(80).build())
.build());
addIndex(context, tableName, "uniq_alm_settings", true, keeCol);
}
private void createProjectAlmSettings(Context context) {
String tableName = "project_alm_settings";
- VarcharColumnDef almSettingUuidCol = newVarcharColumnBuilder("alm_setting_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_VARCHAR_SIZE).build();
- VarcharColumnDef almRepoCol = newVarcharColumnBuilder("alm_repo").setIsNullable(true).setLimit(256).build();
- VarcharColumnDef almSlugCol = newVarcharColumnBuilder("alm_slug").setIsNullable(true).setLimit(256).build();
- BooleanColumnDef summaryCommentEnabledCol = newBooleanColumnBuilder("summary_comment_enabled").setIsNullable(true).build();
- BooleanColumnDef monorepoCol = newBooleanColumnBuilder("monorepo").setIsNullable(false).build();
+ VarcharColumnDef almSettingUuidCol = newVarcharColumnDefBuilder("alm_setting_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_VARCHAR_SIZE).build();
+ VarcharColumnDef almRepoCol = newVarcharColumnDefBuilder("alm_repo").setIsNullable(true).setLimit(256).build();
+ VarcharColumnDef almSlugCol = newVarcharColumnDefBuilder("alm_slug").setIsNullable(true).setLimit(256).build();
+ BooleanColumnDef summaryCommentEnabledCol = newBooleanColumnDefBuilder("summary_comment_enabled").setIsNullable(true).build();
+ BooleanColumnDef monorepoCol = newBooleanColumnDefBuilder("monorepo").setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -259,7 +259,7 @@ public class CreateInitialSchema extends DdlChange {
private void createAnalysisProperties(Context context) {
String tableName = "analysis_properties";
- VarcharColumnDef snapshotUuidColumn = newVarcharColumnBuilder(ANALYSIS_UUID_COL_NAME)
+ VarcharColumnDef snapshotUuidColumn = newVarcharColumnDefBuilder(ANALYSIS_UUID_COL_NAME)
.setIsNullable(false)
.setLimit(UUID_SIZE)
.build();
@@ -267,8 +267,8 @@ public class CreateInitialSchema extends DdlChange {
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(snapshotUuidColumn)
- .addColumn(newVarcharColumnBuilder("kee").setIsNullable(false).setLimit(512).build())
- .addColumn(newVarcharColumnBuilder(TEXT_VALUE_COL_NAME).setIsNullable(true).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("kee").setIsNullable(false).setLimit(512).build())
+ .addColumn(newVarcharColumnDefBuilder(TEXT_VALUE_COL_NAME).setIsNullable(true).setLimit(MAX_SIZE).build())
.addColumn(newClobColumnDefBuilder().setColumnName("clob_value").setIsNullable(true).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_empty").setIsNullable(false).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
@@ -278,10 +278,10 @@ public class CreateInitialSchema extends DdlChange {
private void createAppBranchProjectBranch(Context context) {
String tableName = "app_branch_project_branch";
- VarcharColumnDef applicationBranchUuid = newVarcharColumnBuilder("application_branch_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
- VarcharColumnDef projectBranchUuid = newVarcharColumnBuilder("project_branch_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
- VarcharColumnDef applicationUuid = newVarcharColumnBuilder("application_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
- VarcharColumnDef projectUuid = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef applicationBranchUuid = newVarcharColumnDefBuilder("application_branch_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef projectBranchUuid = newVarcharColumnDefBuilder("project_branch_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef applicationUuid = newVarcharColumnDefBuilder("application_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef projectUuid = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -300,8 +300,8 @@ public class CreateInitialSchema extends DdlChange {
private void createAppProjects(Context context) {
String tableName = "app_projects";
- VarcharColumnDef applicationUuid = newVarcharColumnBuilder("application_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
- VarcharColumnDef projectUuid = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef applicationUuid = newVarcharColumnDefBuilder("application_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef projectUuid = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -318,17 +318,17 @@ public class CreateInitialSchema extends DdlChange {
private void createCeActivity(Context context) {
String tableName = "ce_activity";
VarcharColumnDef uuidCol = UUID_COL;
- VarcharColumnDef mainComponentUuidCol = newVarcharColumnBuilder("main_component_uuid").setLimit(UUID_SIZE).setIsNullable(true).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
- VarcharColumnDef statusCol = newVarcharColumnBuilder(STATUS_COL_NAME).setLimit(15).setIsNullable(false).build();
+ VarcharColumnDef mainComponentUuidCol = newVarcharColumnDefBuilder("main_component_uuid").setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef statusCol = newVarcharColumnDefBuilder(STATUS_COL_NAME).setLimit(15).setIsNullable(false).build();
BooleanColumnDef mainIsLastCol = newBooleanColumnDefBuilder().setColumnName("main_is_last").setIsNullable(false).build();
- VarcharColumnDef mainIsLastKeyCol = newVarcharColumnBuilder("main_is_last_key").setLimit(55).setIsNullable(false).build();
+ VarcharColumnDef mainIsLastKeyCol = newVarcharColumnDefBuilder("main_is_last_key").setLimit(55).setIsNullable(false).build();
BooleanColumnDef isLastCol = newBooleanColumnDefBuilder().setColumnName("is_last").setIsNullable(false).build();
- VarcharColumnDef isLastKeyCol = newVarcharColumnBuilder("is_last_key").setLimit(55).setIsNullable(false).build();
+ VarcharColumnDef isLastKeyCol = newVarcharColumnDefBuilder("is_last_key").setLimit(55).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(uuidCol)
- .addColumn(newVarcharColumnBuilder("task_type").setLimit(15).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("task_type").setLimit(15).setIsNullable(false).build())
.addColumn(mainComponentUuidCol)
.addColumn(componentUuidCol)
.addColumn(statusCol)
@@ -336,17 +336,17 @@ public class CreateInitialSchema extends DdlChange {
.addColumn(mainIsLastKeyCol)
.addColumn(isLastCol)
.addColumn(isLastKeyCol)
- .addColumn(newVarcharColumnBuilder("submitter_uuid").setLimit(USER_UUID_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("submitter_uuid").setLimit(USER_UUID_SIZE).setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("submitted_at").setIsNullable(false).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("started_at").setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("executed_at").setIsNullable(true).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("execution_count").setIsNullable(false).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("execution_time_ms").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder(ANALYSIS_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("error_message").setLimit(1_000).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder(ANALYSIS_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("error_message").setLimit(1_000).setIsNullable(true).build())
.addColumn(newClobColumnDefBuilder().setColumnName("error_stacktrace").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("error_type").setLimit(20).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("worker_uuid").setLimit(UUID_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("error_type").setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("worker_uuid").setLimit(UUID_SIZE).setIsNullable(true).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
.build());
@@ -361,18 +361,18 @@ public class CreateInitialSchema extends DdlChange {
private void createCeQueue(Context context) {
String tableName = "ce_queue";
VarcharColumnDef uuidCol = UUID_COL;
- VarcharColumnDef mainComponentUuidCol = newVarcharColumnBuilder("main_component_uuid").setLimit(UUID_SIZE).setIsNullable(true).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef mainComponentUuidCol = newVarcharColumnDefBuilder("main_component_uuid").setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(uuidCol)
- .addColumn(newVarcharColumnBuilder("task_type").setLimit(15).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("task_type").setLimit(15).setIsNullable(false).build())
.addColumn(mainComponentUuidCol)
.addColumn(componentUuidCol)
- .addColumn(newVarcharColumnBuilder(STATUS_COL_NAME).setLimit(15).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("submitter_uuid").setLimit(USER_UUID_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder(STATUS_COL_NAME).setLimit(15).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("submitter_uuid").setLimit(USER_UUID_SIZE).setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("started_at").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("worker_uuid").setLimit(UUID_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("worker_uuid").setLimit(UUID_SIZE).setIsNullable(true).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("execution_count").setIsNullable(false).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
@@ -384,7 +384,7 @@ public class CreateInitialSchema extends DdlChange {
private void createCeScannerContext(Context context) {
context.execute(
newTableBuilder("ce_scanner_context")
- .addPkColumn(newVarcharColumnBuilder(TASK_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addPkColumn(newVarcharColumnDefBuilder(TASK_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
.addColumn(newBlobColumnDefBuilder().setColumnName("context_data").setIsNullable(false).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
@@ -393,7 +393,7 @@ public class CreateInitialSchema extends DdlChange {
private void createCeTaskCharacteristics(Context context) {
String tableName = "ce_task_characteristics";
- VarcharColumnDef ceTaskUuidColumn = newVarcharColumnBuilder(TASK_UUID_COL_NAME)
+ VarcharColumnDef ceTaskUuidColumn = newVarcharColumnDefBuilder(TASK_UUID_COL_NAME)
.setLimit(UUID_SIZE)
.setIsNullable(false)
.build();
@@ -402,8 +402,8 @@ public class CreateInitialSchema extends DdlChange {
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(ceTaskUuidColumn)
- .addColumn(newVarcharColumnBuilder("kee").setLimit(512).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder(TEXT_VALUE_COL_NAME).setLimit(512).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("kee").setLimit(512).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(TEXT_VALUE_COL_NAME).setLimit(512).setIsNullable(true).build())
.build());
addIndex(context, tableName, "ce_characteristics_" + ceTaskUuidColumn.getName(), false, ceTaskUuidColumn);
}
@@ -411,7 +411,7 @@ public class CreateInitialSchema extends DdlChange {
private void createCeTaskInput(Context context) {
context.execute(
newTableBuilder("ce_task_input")
- .addPkColumn(newVarcharColumnBuilder(TASK_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addPkColumn(newVarcharColumnDefBuilder(TASK_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
.addColumn(newBlobColumnDefBuilder().setColumnName("input_data").setIsNullable(true).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
@@ -420,12 +420,12 @@ public class CreateInitialSchema extends DdlChange {
private void createCeTaskMessage(Context context) {
String tableName = "ce_task_message";
- VarcharColumnDef taskUuidCol = newVarcharColumnBuilder(TASK_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
- VarcharColumnDef messageTypeCol = newVarcharColumnBuilder("message_type").setIsNullable(false).setLimit(255).build();
+ VarcharColumnDef taskUuidCol = newVarcharColumnDefBuilder(TASK_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef messageTypeCol = newVarcharColumnDefBuilder("message_type").setIsNullable(false).setLimit(255).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(taskUuidCol)
- .addColumn(newVarcharColumnBuilder("message").setIsNullable(false).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("message").setIsNullable(false).setLimit(MAX_SIZE).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(messageTypeCol)
.build());
@@ -435,46 +435,46 @@ public class CreateInitialSchema extends DdlChange {
private void createComponents(Context context) {
String tableName = "components";
- VarcharColumnDef keeCol = newVarcharColumnBuilder("kee").setIsNullable(true).setLimit(400).build();
- VarcharColumnDef moduleUuidCol = newVarcharColumnBuilder("module_uuid").setIsNullable(true).setLimit(50).build();
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(50).build();
- VarcharColumnDef qualifierCol = newVarcharColumnBuilder("qualifier").setIsNullable(true).setLimit(10).build();
- VarcharColumnDef rootUuidCol = newVarcharColumnBuilder("root_uuid").setIsNullable(false).setLimit(50).build();
- VarcharColumnDef uuidCol = newVarcharColumnBuilder("uuid").setIsNullable(false).setLimit(50).build();
- VarcharColumnDef mainBranchProjectUuidCol = newVarcharColumnBuilder("main_branch_project_uuid").setIsNullable(true).setLimit(50).build();
+ VarcharColumnDef keeCol = newVarcharColumnDefBuilder("kee").setIsNullable(true).setLimit(400).build();
+ VarcharColumnDef moduleUuidCol = newVarcharColumnDefBuilder("module_uuid").setIsNullable(true).setLimit(50).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(50).build();
+ VarcharColumnDef qualifierCol = newVarcharColumnDefBuilder("qualifier").setIsNullable(true).setLimit(10).build();
+ VarcharColumnDef rootUuidCol = newVarcharColumnDefBuilder("root_uuid").setIsNullable(false).setLimit(50).build();
+ VarcharColumnDef uuidCol = newVarcharColumnDefBuilder("uuid").setIsNullable(false).setLimit(50).build();
+ VarcharColumnDef mainBranchProjectUuidCol = newVarcharColumnDefBuilder("main_branch_project_uuid").setIsNullable(true).setLimit(50).build();
context.execute(newTableBuilder(tableName)
.addColumn(uuidCol)
.addColumn(keeCol)
- .addColumn(newVarcharColumnBuilder("deprecated_kee").setIsNullable(true).setLimit(400).build())
- .addColumn(newVarcharColumnBuilder("name").setIsNullable(true).setLimit(2000).build())
- .addColumn(newVarcharColumnBuilder("long_name").setIsNullable(true).setLimit(2000).build())
- .addColumn(newVarcharColumnBuilder(DESCRIPTION_COL_NAME).setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("deprecated_kee").setIsNullable(true).setLimit(400).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("long_name").setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder(DESCRIPTION_COL_NAME).setIsNullable(true).setLimit(2000).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("enabled").setIsNullable(false).setDefaultValue(true).build())
- .addColumn(newVarcharColumnBuilder("scope").setIsNullable(true).setLimit(3).build())
+ .addColumn(newVarcharColumnDefBuilder("scope").setIsNullable(true).setLimit(3).build())
.addColumn(qualifierCol)
.addColumn(newBooleanColumnDefBuilder().setColumnName("private").setIsNullable(false).build())
.addColumn(rootUuidCol)
- .addColumn(newVarcharColumnBuilder(LANGUAGE_COL_NAME).setIsNullable(true).setLimit(20).build())
- .addColumn(newVarcharColumnBuilder("copy_component_uuid").setIsNullable(true).setLimit(50).build())
- .addColumn(newVarcharColumnBuilder("path").setIsNullable(true).setLimit(2000).build())
- .addColumn(newVarcharColumnBuilder("uuid_path").setIsNullable(false).setLimit(1500).build())
+ .addColumn(newVarcharColumnDefBuilder(LANGUAGE_COL_NAME).setIsNullable(true).setLimit(20).build())
+ .addColumn(newVarcharColumnDefBuilder("copy_component_uuid").setIsNullable(true).setLimit(50).build())
+ .addColumn(newVarcharColumnDefBuilder("path").setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("uuid_path").setIsNullable(false).setLimit(1500).build())
.addColumn(projectUuidCol)
.addColumn(moduleUuidCol)
- .addColumn(newVarcharColumnBuilder("module_uuid_path").setIsNullable(true).setLimit(1500).build())
+ .addColumn(newVarcharColumnDefBuilder("module_uuid_path").setIsNullable(true).setLimit(1500).build())
.addColumn(mainBranchProjectUuidCol)
.addColumn(newBooleanColumnDefBuilder().setColumnName("b_changed").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("b_name").setIsNullable(true).setLimit(500).build())
- .addColumn(newVarcharColumnBuilder("b_long_name").setIsNullable(true).setLimit(500).build())
- .addColumn(newVarcharColumnBuilder("b_description").setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("b_name").setIsNullable(true).setLimit(500).build())
+ .addColumn(newVarcharColumnDefBuilder("b_long_name").setIsNullable(true).setLimit(500).build())
+ .addColumn(newVarcharColumnDefBuilder("b_description").setIsNullable(true).setLimit(2000).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("b_enabled").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("b_qualifier").setIsNullable(true).setLimit(10).build())
- .addColumn(newVarcharColumnBuilder("b_language").setIsNullable(true).setLimit(20).build())
- .addColumn(newVarcharColumnBuilder("b_copy_component_uuid").setIsNullable(true).setLimit(50).build())
- .addColumn(newVarcharColumnBuilder("b_path").setIsNullable(true).setLimit(2000).build())
- .addColumn(newVarcharColumnBuilder("b_uuid_path").setIsNullable(true).setLimit(1500).build())
- .addColumn(newVarcharColumnBuilder("b_module_uuid").setIsNullable(true).setLimit(50).build())
- .addColumn(newVarcharColumnBuilder("b_module_uuid_path").setIsNullable(true).setLimit(1500).build())
+ .addColumn(newVarcharColumnDefBuilder("b_qualifier").setIsNullable(true).setLimit(10).build())
+ .addColumn(newVarcharColumnDefBuilder("b_language").setIsNullable(true).setLimit(20).build())
+ .addColumn(newVarcharColumnDefBuilder("b_copy_component_uuid").setIsNullable(true).setLimit(50).build())
+ .addColumn(newVarcharColumnDefBuilder("b_path").setIsNullable(true).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("b_uuid_path").setIsNullable(true).setLimit(1500).build())
+ .addColumn(newVarcharColumnDefBuilder("b_module_uuid").setIsNullable(true).setLimit(50).build())
+ .addColumn(newVarcharColumnDefBuilder("b_module_uuid_path").setIsNullable(true).setLimit(1500).build())
.addColumn(newTimestampColumnDefBuilder().setColumnName(CREATED_AT_COL_NAME).setIsNullable(true).build())
.build());
@@ -489,14 +489,14 @@ public class CreateInitialSchema extends DdlChange {
private void createDefaultQProfiles(Context context) {
String tableName = "default_qprofiles";
- VarcharColumnDef profileUuidColumn = newVarcharColumnBuilder(QPROFILE_UUID_COL_NAME)
+ VarcharColumnDef profileUuidColumn = newVarcharColumnDefBuilder(QPROFILE_UUID_COL_NAME)
.setLimit(255)
.setIsNullable(false)
.build();
context.execute(
newTableBuilder(tableName)
- .addPkColumn(newVarcharColumnBuilder(LANGUAGE_COL_NAME).setLimit(20).setIsNullable(false).build())
+ .addPkColumn(newVarcharColumnDefBuilder(LANGUAGE_COL_NAME).setLimit(20).setIsNullable(false).build())
.addColumn(profileUuidColumn)
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
@@ -506,9 +506,9 @@ public class CreateInitialSchema extends DdlChange {
private void createDeprecatedRuleKeys(Context context) {
String tableName = "deprecated_rule_keys";
- VarcharColumnDef ruleUuidCol = newVarcharColumnBuilder(RULE_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
- VarcharColumnDef oldRepositoryKeyCol = newVarcharColumnBuilder("old_repository_key").setIsNullable(false).setLimit(255).build();
- VarcharColumnDef oldRuleKeyCol = newVarcharColumnBuilder("old_rule_key").setIsNullable(false).setLimit(200).build();
+ VarcharColumnDef ruleUuidCol = newVarcharColumnDefBuilder(RULE_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef oldRepositoryKeyCol = newVarcharColumnDefBuilder("old_repository_key").setIsNullable(false).setLimit(255).build();
+ VarcharColumnDef oldRuleKeyCol = newVarcharColumnDefBuilder("old_rule_key").setIsNullable(false).setLimit(200).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(oldRepositoryKeyCol)
@@ -522,9 +522,9 @@ public class CreateInitialSchema extends DdlChange {
private void createDuplicationsIndex(Context context) {
String tableName = "duplications_index";
- VarcharColumnDef hashCol = newVarcharColumnBuilder("hash").setLimit(50).setIsNullable(false).build();
- VarcharColumnDef analysisUuidCol = newVarcharColumnBuilder(ANALYSIS_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef hashCol = newVarcharColumnDefBuilder("hash").setLimit(50).setIsNullable(false).build();
+ VarcharColumnDef analysisUuidCol = newVarcharColumnDefBuilder(ANALYSIS_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -546,10 +546,10 @@ public class CreateInitialSchema extends DdlChange {
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("doc_type").setIsNullable(false).setLimit(40).build())
- .addColumn(newVarcharColumnBuilder("doc_id").setIsNullable(false).setLimit(MAX_SIZE).build())
- .addColumn(newVarcharColumnBuilder("doc_id_type").setIsNullable(true).setLimit(20).build())
- .addColumn(newVarcharColumnBuilder("doc_routing").setIsNullable(true).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("doc_type").setIsNullable(false).setLimit(40).build())
+ .addColumn(newVarcharColumnDefBuilder("doc_id").setIsNullable(false).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("doc_id_type").setIsNullable(true).setLimit(20).build())
+ .addColumn(newVarcharColumnDefBuilder("doc_routing").setIsNullable(true).setLimit(MAX_SIZE).build())
.addColumn(createdAtCol)
.build());
addIndex(context, tableName, "es_queue_created_at", false, createdAtCol);
@@ -557,11 +557,11 @@ public class CreateInitialSchema extends DdlChange {
private void createEventComponentChanges(Context context) {
String tableName = "event_component_changes";
- VarcharColumnDef eventUuidCol = newVarcharColumnBuilder("event_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
- VarcharColumnDef eventComponentUuidCol = newVarcharColumnBuilder("event_component_uuid").setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
- VarcharColumnDef eventAnalysisUuidCol = newVarcharColumnBuilder("event_analysis_uuid").setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
- VarcharColumnDef changeCategoryCol = newVarcharColumnBuilder("change_category").setIsNullable(false).setLimit(12).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
+ VarcharColumnDef eventUuidCol = newVarcharColumnDefBuilder("event_uuid").setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef eventComponentUuidCol = newVarcharColumnDefBuilder("event_component_uuid").setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
+ VarcharColumnDef eventAnalysisUuidCol = newVarcharColumnDefBuilder("event_analysis_uuid").setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
+ VarcharColumnDef changeCategoryCol = newVarcharColumnDefBuilder("change_category").setIsNullable(false).setLimit(12).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(eventUuidCol)
@@ -569,9 +569,9 @@ public class CreateInitialSchema extends DdlChange {
.addColumn(eventAnalysisUuidCol)
.addColumn(changeCategoryCol)
.addColumn(componentUuidCol)
- .addColumn(newVarcharColumnBuilder("component_key").setIsNullable(false).setLimit(400).build())
- .addColumn(newVarcharColumnBuilder("component_name").setIsNullable(false).setLimit(2000).build())
- .addColumn(newVarcharColumnBuilder("component_branch_key").setIsNullable(true).setLimit(255).build())
+ .addColumn(newVarcharColumnDefBuilder("component_key").setIsNullable(false).setLimit(400).build())
+ .addColumn(newVarcharColumnDefBuilder("component_name").setIsNullable(false).setLimit(2000).build())
+ .addColumn(newVarcharColumnDefBuilder("component_branch_key").setIsNullable(true).setLimit(255).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.build());
addIndex(context, tableName, tableName + UNIQUE_INDEX_SUFFIX, true, eventUuidCol, changeCategoryCol, componentUuidCol);
@@ -582,16 +582,16 @@ public class CreateInitialSchema extends DdlChange {
private void createEvents(Context context) {
String tableName = "events";
VarcharColumnDef uuidCol = UUID_COL;
- VarcharColumnDef analysisUuidCol = newVarcharColumnBuilder(ANALYSIS_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
- VarcharColumnDef componentUuid = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef analysisUuidCol = newVarcharColumnDefBuilder(ANALYSIS_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef componentUuid = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(uuidCol)
.addColumn(analysisUuidCol)
- .addColumn(newVarcharColumnBuilder("name").setLimit(400).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("category").setLimit(50).build())
- .addColumn(newVarcharColumnBuilder(DESCRIPTION_COL_NAME).setLimit(MAX_SIZE).build())
- .addColumn(newVarcharColumnBuilder("event_data").setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(400).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("category").setLimit(50).build())
+ .addColumn(newVarcharColumnDefBuilder(DESCRIPTION_COL_NAME).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("event_data").setLimit(MAX_SIZE).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("event_date").setIsNullable(false).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(componentUuid)
@@ -602,9 +602,9 @@ public class CreateInitialSchema extends DdlChange {
private void createFileSources(Context context) {
String tableName = "file_sources";
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
BigIntegerColumnDef updatedAtCol = TECHNICAL_UPDATED_AT_COL;
- VarcharColumnDef fileUuidCol = newVarcharColumnBuilder("file_uuid").setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef fileUuidCol = newVarcharColumnDefBuilder("file_uuid").setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -612,9 +612,9 @@ public class CreateInitialSchema extends DdlChange {
.addColumn(fileUuidCol)
.addColumn(newClobColumnDefBuilder().setColumnName("line_hashes").setIsNullable(true).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("line_hashes_version").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("data_hash").setLimit(50).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("src_hash").setLimit(50).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("revision").setLimit(100).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("data_hash").setLimit(50).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("src_hash").setLimit(50).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("revision").setLimit(100).setIsNullable(true).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("line_count").setIsNullable(false).build())
.addColumn(newBlobColumnDefBuilder().setColumnName("binary_data").setIsNullable(true).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
@@ -627,9 +627,9 @@ public class CreateInitialSchema extends DdlChange {
private void createGroupRoles(Context context) {
String tableName = "group_roles";
- VarcharColumnDef roleCol = newVarcharColumnBuilder("role").setLimit(64).setIsNullable(false).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setIsNullable(true).setLimit(UUID_SIZE).build();
- VarcharColumnDef groupUuidCol = newVarcharColumnBuilder(GROUP_UUID_COL_NAME).setIsNullable(true).setLimit(UUID_SIZE).build();
+ VarcharColumnDef roleCol = newVarcharColumnDefBuilder("role").setLimit(64).setIsNullable(false).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setIsNullable(true).setLimit(UUID_SIZE).build();
+ VarcharColumnDef groupUuidCol = newVarcharColumnDefBuilder(GROUP_UUID_COL_NAME).setIsNullable(true).setLimit(UUID_SIZE).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -643,12 +643,12 @@ public class CreateInitialSchema extends DdlChange {
private void createGroups(Context context) {
String tableName = "groups";
- VarcharColumnDef nameCol = newVarcharColumnBuilder("name").setLimit(500).setIsNullable(false).build();
+ VarcharColumnDef nameCol = newVarcharColumnDefBuilder("name").setLimit(500).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(nameCol)
- .addColumn(newVarcharColumnBuilder(DESCRIPTION_COL_NAME).setLimit(200).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder(DESCRIPTION_COL_NAME).setLimit(200).setIsNullable(true).build())
.addColumn(DEPRECATED_TECHNICAL_CREATED_AT_COL)
.addColumn(DEPRECATED_TECHNICAL_UPDATED_AT_COL)
.build());
@@ -657,8 +657,8 @@ public class CreateInitialSchema extends DdlChange {
private void createGroupsUsers(Context context) {
String tableName = "groups_users";
- VarcharColumnDef groupUuidCol = newVarcharColumnBuilder(GROUP_UUID_COL_NAME).setLimit(40).setIsNullable(false).build();
- VarcharColumnDef userUuidCol = newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef groupUuidCol = newVarcharColumnDefBuilder(GROUP_UUID_COL_NAME).setLimit(40).setIsNullable(false).build();
+ VarcharColumnDef userUuidCol = newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(255).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addColumn(groupUuidCol)
@@ -671,13 +671,13 @@ public class CreateInitialSchema extends DdlChange {
private void createInternalComponentProps(Context context) {
String tableName = "internal_component_props";
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
- VarcharColumnDef keeCol = newVarcharColumnBuilder("kee").setIsNullable(false).setLimit(512).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
+ VarcharColumnDef keeCol = newVarcharColumnDefBuilder("kee").setIsNullable(false).setLimit(512).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(componentUuidCol)
.addColumn(keeCol)
- .addColumn(newVarcharColumnBuilder(VALUE_COL_NAME).setIsNullable(true).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder(VALUE_COL_NAME).setIsNullable(true).setLimit(MAX_SIZE).build())
.addColumn(TECHNICAL_UPDATED_AT_COL)
.addColumn(TECHNICAL_CREATED_AT_COL)
.build());
@@ -687,7 +687,7 @@ public class CreateInitialSchema extends DdlChange {
private void createInternalProperties(Context context) {
context.execute(
newTableBuilder("internal_properties")
- .addPkColumn(newVarcharColumnBuilder("kee").setLimit(20).setIsNullable(false).build())
+ .addPkColumn(newVarcharColumnDefBuilder("kee").setLimit(20).setIsNullable(false).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_empty").setIsNullable(false).build())
.addColumn(newVarcharColumnDefBuilder().setColumnName(TEXT_VALUE_COL_NAME).setLimit(MAX_SIZE).setIgnoreOracleUnit(true).build())
.addColumn(newClobColumnDefBuilder().setColumnName("clob_value").setIsNullable(true).build())
@@ -697,16 +697,16 @@ public class CreateInitialSchema extends DdlChange {
private void createIssueChanges(Context context) {
String tableName = "issue_changes";
- VarcharColumnDef issueKeyCol = newVarcharColumnBuilder("issue_key").setLimit(50).setIsNullable(false).build();
- VarcharColumnDef keeCol = newVarcharColumnBuilder("kee").setLimit(50).build();
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(50).setIsNullable(false).build();
+ VarcharColumnDef issueKeyCol = newVarcharColumnDefBuilder("issue_key").setLimit(50).setIsNullable(false).build();
+ VarcharColumnDef keeCol = newVarcharColumnDefBuilder("kee").setLimit(50).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(50).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(keeCol)
.addColumn(issueKeyCol)
- .addColumn(newVarcharColumnBuilder("user_login").setLimit(USER_UUID_SIZE).build())
- .addColumn(newVarcharColumnBuilder("change_type").setLimit(20).build())
+ .addColumn(newVarcharColumnDefBuilder("user_login").setLimit(USER_UUID_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("change_type").setLimit(20).build())
.addColumn(newClobColumnDefBuilder().setColumnName("change_data").build())
.addColumn(NULLABLE_TECHNICAL_CREATED_AT_COL)
.addColumn(NULLABLE_TECHNICAL_UPDATED_AT_COL)
@@ -720,39 +720,39 @@ public class CreateInitialSchema extends DdlChange {
private void createIssues(Context context) {
var tableName = "issues";
- VarcharColumnDef assigneeCol = newVarcharColumnBuilder("assignee").setLimit(USER_UUID_SIZE).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(50).build();
+ VarcharColumnDef assigneeCol = newVarcharColumnDefBuilder("assignee").setLimit(USER_UUID_SIZE).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(50).build();
BigIntegerColumnDef issueCreationDateCol = newBigIntegerColumnDefBuilder().setColumnName("issue_creation_date").build();
- VarcharColumnDef keeCol = newVarcharColumnBuilder("kee").setLimit(50).setIsNullable(false).build();
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(50).build();
- VarcharColumnDef resolutionCol = newVarcharColumnBuilder("resolution").setLimit(20).build();
- VarcharColumnDef ruleUuidCol = newVarcharColumnBuilder(RULE_UUID_COL_NAME).setLimit(40).setIsNullable(true).build();
+ VarcharColumnDef keeCol = newVarcharColumnDefBuilder("kee").setLimit(50).setIsNullable(false).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(50).build();
+ VarcharColumnDef resolutionCol = newVarcharColumnDefBuilder("resolution").setLimit(20).build();
+ VarcharColumnDef ruleUuidCol = newVarcharColumnDefBuilder(RULE_UUID_COL_NAME).setLimit(40).setIsNullable(true).build();
BigIntegerColumnDef updatedAtCol = NULLABLE_TECHNICAL_UPDATED_AT_COL;
context.execute(
newTableBuilder(tableName)
.addPkColumn(keeCol)
.addColumn(ruleUuidCol)
- .addColumn(newVarcharColumnBuilder("severity").setLimit(10).build())
+ .addColumn(newVarcharColumnDefBuilder("severity").setLimit(10).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("manual_severity").setIsNullable(false).build())
// unit has been fixed in SonarQube 5.6 (see migration 1151, SONAR-7493)
- .addColumn(newVarcharColumnBuilder("message").setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("message").setLimit(MAX_SIZE).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("line").build())
.addColumn(newDecimalColumnDefBuilder().setColumnName("gap").setPrecision(30).setScale(20).build())
- .addColumn(newVarcharColumnBuilder(STATUS_COL_NAME).setLimit(20).build())
+ .addColumn(newVarcharColumnDefBuilder(STATUS_COL_NAME).setLimit(20).build())
.addColumn(resolutionCol)
- .addColumn(newVarcharColumnBuilder("checksum").setLimit(1000).build())
- .addColumn(newVarcharColumnBuilder("reporter").setLimit(USER_UUID_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("checksum").setLimit(1000).build())
+ .addColumn(newVarcharColumnDefBuilder("reporter").setLimit(USER_UUID_SIZE).build())
.addColumn(assigneeCol)
- .addColumn(newVarcharColumnBuilder("author_login").setLimit(255).build())
- .addColumn(newVarcharColumnBuilder("action_plan_key").setLimit(50).build())
- .addColumn(newVarcharColumnBuilder("issue_attributes").setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("author_login").setLimit(255).build())
+ .addColumn(newVarcharColumnDefBuilder("action_plan_key").setLimit(50).build())
+ .addColumn(newVarcharColumnDefBuilder("issue_attributes").setLimit(MAX_SIZE).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("effort").build())
.addColumn(NULLABLE_TECHNICAL_CREATED_AT_COL)
.addColumn(updatedAtCol)
.addColumn(issueCreationDateCol)
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("issue_update_date").build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("issue_close_date").build())
- .addColumn(newVarcharColumnBuilder("tags").setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("tags").setLimit(MAX_SIZE).build())
.addColumn(componentUuidCol)
.addColumn(projectUuidCol)
.addColumn(newBlobColumnDefBuilder().setColumnName("locations").build())
@@ -771,19 +771,19 @@ public class CreateInitialSchema extends DdlChange {
private void createLiveMeasures(Context context) {
String tableName = "live_measures";
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
- VarcharColumnDef metricUuidCol = newVarcharColumnBuilder(METRIC_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
+ VarcharColumnDef metricUuidCol = newVarcharColumnDefBuilder(METRIC_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(projectUuidCol)
.addColumn(componentUuidCol)
.addColumn(metricUuidCol)
.addColumn(newDecimalColumnDefBuilder().setColumnName(VALUE_COL_NAME).setPrecision(38).setScale(20).build())
- .addColumn(newVarcharColumnBuilder(TEXT_VALUE_COL_NAME).setIsNullable(true).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder(TEXT_VALUE_COL_NAME).setIsNullable(true).setLimit(MAX_SIZE).build())
.addColumn(newDecimalColumnDefBuilder().setColumnName("variation").setPrecision(38).setScale(20).build())
.addColumn(newBlobColumnDefBuilder().setColumnName("measure_data").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("update_marker").setIsNullable(true).setLimit(UUID_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("update_marker").setIsNullable(true).setLimit(UUID_SIZE).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
.build());
@@ -793,35 +793,35 @@ public class CreateInitialSchema extends DdlChange {
private void createManualMeasures(Context context) {
String tableName = "manual_measures";
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(newDecimalColumnDefBuilder().setColumnName(VALUE_COL_NAME).setPrecision(38).setScale(20).build())
- .addColumn(newVarcharColumnBuilder(TEXT_VALUE_COL_NAME).setLimit(MAX_SIZE).build())
- .addColumn(newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).build())
- .addColumn(newVarcharColumnBuilder(DESCRIPTION_COL_NAME).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder(TEXT_VALUE_COL_NAME).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder(DESCRIPTION_COL_NAME).setLimit(MAX_SIZE).build())
.addColumn(NULLABLE_TECHNICAL_CREATED_AT_COL)
.addColumn(NULLABLE_TECHNICAL_UPDATED_AT_COL)
.addColumn(componentUuidCol)
- .addColumn(newVarcharColumnBuilder(METRIC_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(METRIC_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
.build());
addIndex(context, tableName, "manual_measures_component_uuid", false, componentUuidCol);
}
private void createMetrics(Context context) {
String tableName = "metrics";
- VarcharColumnDef nameCol = newVarcharColumnBuilder("name").setLimit(64).setIsNullable(false).build();
+ VarcharColumnDef nameCol = newVarcharColumnDefBuilder("name").setLimit(64).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(nameCol)
- .addColumn(newVarcharColumnBuilder(DESCRIPTION_COL_NAME).setLimit(255).build())
+ .addColumn(newVarcharColumnDefBuilder(DESCRIPTION_COL_NAME).setLimit(255).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("direction").setIsNullable(false).setDefaultValue(0).build())
- .addColumn(newVarcharColumnBuilder("domain").setLimit(64).build())
- .addColumn(newVarcharColumnBuilder("short_name").setLimit(64).build())
+ .addColumn(newVarcharColumnDefBuilder("domain").setLimit(64).build())
+ .addColumn(newVarcharColumnDefBuilder("short_name").setLimit(64).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("qualitative").setDefaultValue(false).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("val_type").setLimit(8).build())
+ .addColumn(newVarcharColumnDefBuilder("val_type").setLimit(8).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("user_managed").setDefaultValue(false).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("enabled").setDefaultValue(true).build())
.addColumn(newDecimalColumnDefBuilder().setColumnName("worst_value").setPrecision(38).setScale(20).build())
@@ -836,10 +836,10 @@ public class CreateInitialSchema extends DdlChange {
private void createNewCodePeriods(Context context) {
String tableName = "new_code_periods";
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
- VarcharColumnDef branchUuidCol = newVarcharColumnBuilder("branch_uuid").setLimit(UUID_SIZE).setIsNullable(true).build();
- VarcharColumnDef typeCol = newVarcharColumnBuilder("type").setLimit(30).setIsNullable(false).build();
- VarcharColumnDef valueCol = newVarcharColumnBuilder(VALUE_COL_NAME).setLimit(255).setIsNullable(true).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef branchUuidCol = newVarcharColumnDefBuilder("branch_uuid").setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef typeCol = newVarcharColumnDefBuilder("type").setLimit(30).setIsNullable(false).build();
+ VarcharColumnDef valueCol = newVarcharColumnDefBuilder(VALUE_COL_NAME).setLimit(255).setIsNullable(true).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -868,8 +868,8 @@ public class CreateInitialSchema extends DdlChange {
private void createOrgQProfiles(Context context) {
String tableName = "org_qprofiles";
int profileUuidSize = 255;
- VarcharColumnDef rulesProfileUuidCol = newVarcharColumnBuilder("rules_profile_uuid").setLimit(profileUuidSize).setIsNullable(false).build();
- VarcharColumnDef parentUuidCol = newVarcharColumnBuilder("parent_uuid").setLimit(profileUuidSize).setIsNullable(true).build();
+ VarcharColumnDef rulesProfileUuidCol = newVarcharColumnDefBuilder("rules_profile_uuid").setLimit(profileUuidSize).setIsNullable(false).build();
+ VarcharColumnDef parentUuidCol = newVarcharColumnDefBuilder("parent_uuid").setLimit(profileUuidSize).setIsNullable(true).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(newVarcharColumnDefBuilder().setColumnName("uuid").setIsNullable(false).setLimit(255).build())
@@ -888,11 +888,11 @@ public class CreateInitialSchema extends DdlChange {
context.execute(
newTableBuilder("perm_templates_groups")
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("permission_reference").setLimit(64).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("permission_reference").setLimit(64).setIsNullable(false).build())
.addColumn(DEPRECATED_TECHNICAL_CREATED_AT_COL)
.addColumn(DEPRECATED_TECHNICAL_UPDATED_AT_COL)
- .addColumn(newVarcharColumnBuilder(TEMPLATE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder(GROUP_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder(TEMPLATE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(GROUP_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build())
.build());
}
@@ -900,18 +900,18 @@ public class CreateInitialSchema extends DdlChange {
context.execute(
newTableBuilder("perm_templates_users")
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("permission_reference").setLimit(64).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("permission_reference").setLimit(64).setIsNullable(false).build())
.addColumn(DEPRECATED_TECHNICAL_CREATED_AT_COL)
.addColumn(DEPRECATED_TECHNICAL_UPDATED_AT_COL)
- .addColumn(newVarcharColumnBuilder(TEMPLATE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(TEMPLATE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(false).build())
.build());
}
private void createPermTemplatesCharacteristics(Context context) {
String tableName = "perm_tpl_characteristics";
- VarcharColumnDef permissionKeyColumn = newVarcharColumnBuilder("permission_key").setLimit(64).setIsNullable(false).build();
- VarcharColumnDef templateUuidColumn = newVarcharColumnBuilder(TEMPLATE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef permissionKeyColumn = newVarcharColumnDefBuilder("permission_key").setLimit(64).setIsNullable(false).build();
+ VarcharColumnDef templateUuidColumn = newVarcharColumnDefBuilder(TEMPLATE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -929,62 +929,62 @@ public class CreateInitialSchema extends DdlChange {
context.execute(
newTableBuilder("permission_templates")
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("name").setLimit(100).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder(DESCRIPTION_COL_NAME).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(100).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(DESCRIPTION_COL_NAME).setLimit(MAX_SIZE).build())
.addColumn(DEPRECATED_TECHNICAL_CREATED_AT_COL)
.addColumn(DEPRECATED_TECHNICAL_UPDATED_AT_COL)
- .addColumn(newVarcharColumnBuilder("key_pattern").setLimit(500).build())
+ .addColumn(newVarcharColumnDefBuilder("key_pattern").setLimit(500).build())
.build());
}
private void createPlugins(Context context) {
int pluginKeyMaxSize = 200;
String tableName = "plugins";
- VarcharColumnDef keyColumn = newVarcharColumnBuilder("kee").setLimit(pluginKeyMaxSize).setIsNullable(false).build();
+ VarcharColumnDef keyColumn = newVarcharColumnDefBuilder("kee").setLimit(pluginKeyMaxSize).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(keyColumn)
- .addColumn(newVarcharColumnBuilder("base_plugin_key").setLimit(pluginKeyMaxSize).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("file_hash").setLimit(200).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("base_plugin_key").setLimit(pluginKeyMaxSize).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("file_hash").setLimit(200).setIsNullable(false).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
- .addColumn(newVarcharColumnBuilder("type").setLimit(10).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("type").setLimit(10).setIsNullable(false).build())
.build());
addIndex(context, tableName, "plugins_key", true, keyColumn);
}
private void createProjectBranches(Context context) {
String tableName = "project_branches";
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
- VarcharColumnDef keeCol = newVarcharColumnBuilder("kee").setIsNullable(false).setLimit(255).build();
- VarcharColumnDef branchTypeCol = newVarcharColumnBuilder("branch_type").setIsNullable(false).setLimit(12).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build();
+ VarcharColumnDef keeCol = newVarcharColumnDefBuilder("kee").setIsNullable(false).setLimit(255).build();
+ VarcharColumnDef branchTypeCol = newVarcharColumnDefBuilder("branch_type").setIsNullable(false).setLimit(12).build();
context.execute(
newTableBuilder(tableName)
- .addPkColumn(newVarcharColumnBuilder("uuid").setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build())
+ .addPkColumn(newVarcharColumnDefBuilder("uuid").setIsNullable(false).setLimit(OLD_UUID_VARCHAR_SIZE).build())
.addColumn(projectUuidCol)
.addColumn(keeCol)
.addColumn(branchTypeCol)
- .addColumn(newVarcharColumnBuilder("merge_branch_uuid").setIsNullable(true).setLimit(OLD_UUID_VARCHAR_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("merge_branch_uuid").setIsNullable(true).setLimit(OLD_UUID_VARCHAR_SIZE).build())
.addColumn(newBlobColumnDefBuilder().setColumnName("pull_request_binary").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("manual_baseline_analysis_uuid").setIsNullable(true).setLimit(UUID_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("manual_baseline_analysis_uuid").setIsNullable(true).setLimit(UUID_SIZE).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
- .addColumn(newBooleanColumnBuilder("exclude_from_purge").setDefaultValue(false).setIsNullable(false).build())
- .addColumn(newBooleanColumnBuilder("need_issue_sync").setIsNullable(false).build())
+ .addColumn(newBooleanColumnDefBuilder("exclude_from_purge").setDefaultValue(false).setIsNullable(false).build())
+ .addColumn(newBooleanColumnDefBuilder("need_issue_sync").setIsNullable(false).build())
.build());
addIndex(context, tableName, "uniq_project_branches", true, branchTypeCol, projectUuidCol, keeCol);
}
private void createProjectLinks(Context context) {
String tableName = "project_links";
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(projectUuidCol)
- .addColumn(newVarcharColumnBuilder("link_type").setLimit(20).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("name").setLimit(128).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("href").setLimit(2048).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("link_type").setLimit(20).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(128).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("href").setLimit(2048).setIsNullable(false).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
.build());
@@ -993,9 +993,9 @@ public class CreateInitialSchema extends DdlChange {
private void createProjectMappings(Context context) {
String tableName = "project_mappings";
- VarcharColumnDef keyTypeCol = newVarcharColumnBuilder("key_type").setIsNullable(false).setLimit(200).build();
- VarcharColumnDef keyCol = newVarcharColumnBuilder("kee").setIsNullable(false).setLimit(MAX_SIZE).build();
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
+ VarcharColumnDef keyTypeCol = newVarcharColumnDefBuilder("key_type").setIsNullable(false).setLimit(200).build();
+ VarcharColumnDef keyCol = newVarcharColumnDefBuilder("kee").setIsNullable(false).setLimit(MAX_SIZE).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setIsNullable(false).setLimit(UUID_SIZE).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(keyTypeCol)
@@ -1010,18 +1010,18 @@ public class CreateInitialSchema extends DdlChange {
private void createProjectMeasures(Context context) {
String tableName = "project_measures";
IntegerColumnDef personIdCol = newIntegerColumnDefBuilder().setColumnName("person_id").build();
- VarcharColumnDef metricUuidCol = newVarcharColumnBuilder(METRIC_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef analysisUuidCol = newVarcharColumnBuilder(ANALYSIS_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef metricUuidCol = newVarcharColumnDefBuilder(METRIC_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef analysisUuidCol = newVarcharColumnDefBuilder(ANALYSIS_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(newDecimalColumnDefBuilder().setColumnName(VALUE_COL_NAME).setPrecision(38).setScale(20).build())
.addColumn(analysisUuidCol)
.addColumn(componentUuidCol)
- .addColumn(newVarcharColumnBuilder(TEXT_VALUE_COL_NAME).setLimit(MAX_SIZE).build())
- .addColumn(newVarcharColumnBuilder("alert_status").setLimit(5).build())
- .addColumn(newVarcharColumnBuilder("alert_text").setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder(TEXT_VALUE_COL_NAME).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("alert_status").setLimit(5).build())
+ .addColumn(newVarcharColumnDefBuilder("alert_text").setLimit(MAX_SIZE).build())
.addColumn(personIdCol)
.addColumn(newDecimalColumnDefBuilder().setColumnName("variation_value_1").setPrecision(38).setScale(20).build())
.addColumn(newBlobColumnDefBuilder().setColumnName("measure_data").build())
@@ -1034,8 +1034,8 @@ public class CreateInitialSchema extends DdlChange {
private void createProjectQprofiles(Context context) {
String tableName = "project_qprofiles";
- VarcharColumnDef projectUuid = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(50).setIsNullable(false).build();
- VarcharColumnDef profileKey = newVarcharColumnBuilder("profile_key").setLimit(50).setIsNullable(false).build();
+ VarcharColumnDef projectUuid = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(50).setIsNullable(false).build();
+ VarcharColumnDef profileKey = newVarcharColumnDefBuilder("profile_key").setLimit(50).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -1048,17 +1048,17 @@ public class CreateInitialSchema extends DdlChange {
private void createProjects(Context context) {
String tableName = "projects";
VarcharColumnDef uuidCol = UUID_COL;
- VarcharColumnDef keeCol = newVarcharColumnBuilder("kee").setLimit(400).setIsNullable(false).build();
- VarcharColumnDef qualifierCol = newVarcharColumnBuilder("qualifier").setLimit(10).setIsNullable(false).build();
+ VarcharColumnDef keeCol = newVarcharColumnDefBuilder("kee").setLimit(400).setIsNullable(false).build();
+ VarcharColumnDef qualifierCol = newVarcharColumnDefBuilder("qualifier").setLimit(10).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(uuidCol)
.addColumn(keeCol)
.addColumn(qualifierCol)
- .addColumn(newVarcharColumnBuilder("name").setLimit(2_000).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder(DESCRIPTION_COL_NAME).setLimit(2_000).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(2_000).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder(DESCRIPTION_COL_NAME).setLimit(2_000).setIsNullable(true).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("private").setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("tags").setLimit(500).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("tags").setLimit(500).setIsNullable(true).build())
.addColumn(NULLABLE_TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
.withPkConstraintName("pk_new_projects")
@@ -1069,8 +1069,8 @@ public class CreateInitialSchema extends DdlChange {
private void createProjectQGates(Context context) {
String tableName = "project_qgates";
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef qualityGateUuidCol = newVarcharColumnBuilder("quality_gate_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef qualityGateUuidCol = newVarcharColumnDefBuilder("quality_gate_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(projectUuidCol)
@@ -1081,12 +1081,12 @@ public class CreateInitialSchema extends DdlChange {
private void createProperties(Context context) {
String tableName = "properties";
- VarcharColumnDef propKey = newVarcharColumnBuilder("prop_key").setLimit(512).setIsNullable(false).build();
+ VarcharColumnDef propKey = newVarcharColumnDefBuilder("prop_key").setLimit(512).setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(propKey)
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_empty").setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder(TEXT_VALUE_COL_NAME).setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder(TEXT_VALUE_COL_NAME).setLimit(MAX_SIZE).build())
.addColumn(newClobColumnDefBuilder().setColumnName("clob_value").setIsNullable(true).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(newVarcharColumnDefBuilder().setColumnName(COMPONENT_UUID_COL_NAME).setIsNullable(true).setLimit(UUID_SIZE).build())
@@ -1099,12 +1099,12 @@ public class CreateInitialSchema extends DdlChange {
private void createQProfileChanges(Context context) {
String tableName = "qprofile_changes";
- VarcharColumnDef rulesProfileUuidCol = newVarcharColumnBuilder("rules_profile_uuid").setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef rulesProfileUuidCol = newVarcharColumnDefBuilder("rules_profile_uuid").setLimit(255).setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
- .addPkColumn(newVarcharColumnBuilder("kee").setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addPkColumn(newVarcharColumnDefBuilder("kee").setLimit(UUID_SIZE).setIsNullable(false).build())
.addColumn(rulesProfileUuidCol)
- .addColumn(newVarcharColumnBuilder("change_type").setLimit(20).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("change_type").setLimit(20).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(true).build())
.addColumn(newClobColumnDefBuilder().setColumnName("change_data").setIsNullable(true).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.build());
@@ -1113,8 +1113,8 @@ public class CreateInitialSchema extends DdlChange {
private void createQProfileEditGroups(Context context) {
String tableName = "qprofile_edit_groups";
- VarcharColumnDef qProfileUuidCol = newVarcharColumnBuilder(QPROFILE_UUID_COL_NAME).setIsNullable(false).setLimit(255).build();
- VarcharColumnDef groupUuidCol = newVarcharColumnBuilder(GROUP_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef qProfileUuidCol = newVarcharColumnDefBuilder(QPROFILE_UUID_COL_NAME).setIsNullable(false).setLimit(255).build();
+ VarcharColumnDef groupUuidCol = newVarcharColumnDefBuilder(GROUP_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(qProfileUuidCol)
@@ -1127,8 +1127,8 @@ public class CreateInitialSchema extends DdlChange {
private void createQProfileEditUsers(Context context) {
String tableName = "qprofile_edit_users";
- VarcharColumnDef qProfileUuidCol = newVarcharColumnBuilder(QPROFILE_UUID_COL_NAME).setLimit(255).setIsNullable(false).build();
- VarcharColumnDef userUuidCol = newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef qProfileUuidCol = newVarcharColumnDefBuilder(QPROFILE_UUID_COL_NAME).setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef userUuidCol = newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(255).setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(qProfileUuidCol)
@@ -1143,12 +1143,12 @@ public class CreateInitialSchema extends DdlChange {
context.execute(
newTableBuilder("quality_gate_conditions")
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("operator").setLimit(3).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("value_error").setLimit(64).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("operator").setLimit(3).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("value_error").setLimit(64).setIsNullable(true).build())
.addColumn(DEPRECATED_TECHNICAL_CREATED_AT_COL)
.addColumn(DEPRECATED_TECHNICAL_UPDATED_AT_COL)
- .addColumn(newVarcharColumnBuilder(METRIC_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("qgate_uuid").setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(METRIC_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("qgate_uuid").setLimit(UUID_SIZE).setIsNullable(false).build())
.build());
}
@@ -1156,7 +1156,7 @@ public class CreateInitialSchema extends DdlChange {
context.execute(
newTableBuilder("quality_gates")
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("name").setLimit(100).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(100).setIsNullable(false).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_built_in").setIsNullable(false).build())
.addColumn(DEPRECATED_TECHNICAL_CREATED_AT_COL)
.addColumn(DEPRECATED_TECHNICAL_UPDATED_AT_COL)
@@ -1165,7 +1165,7 @@ public class CreateInitialSchema extends DdlChange {
private void createSessionTokens(Context context) {
String tableName = "session_tokens";
- VarcharColumnDef userUuidCol = newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef userUuidCol = newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(255).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -1181,43 +1181,43 @@ public class CreateInitialSchema extends DdlChange {
private void createRulesRepository(Context context) {
String tableName = "rule_repositories";
context.execute(newTableBuilder(tableName)
- .addPkColumn(newVarcharColumnBuilder("kee").setLimit(200).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder(LANGUAGE_COL_NAME).setLimit(20).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("name").setLimit(4_000).setIsNullable(false).build())
+ .addPkColumn(newVarcharColumnDefBuilder("kee").setLimit(200).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(LANGUAGE_COL_NAME).setLimit(20).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(4_000).setIsNullable(false).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.build());
}
private void createRules(Context context) {
- VarcharColumnDef pluginRuleKeyCol = newVarcharColumnBuilder("plugin_rule_key").setLimit(200).setIsNullable(false).build();
- VarcharColumnDef pluginNameCol = newVarcharColumnBuilder("plugin_name").setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef pluginRuleKeyCol = newVarcharColumnDefBuilder("plugin_rule_key").setLimit(200).setIsNullable(false).build();
+ VarcharColumnDef pluginNameCol = newVarcharColumnDefBuilder("plugin_name").setLimit(255).setIsNullable(false).build();
context.execute(
newTableBuilder("rules")
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("name").setLimit(200).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(200).setIsNullable(true).build())
.addColumn(pluginRuleKeyCol)
- .addColumn(newVarcharColumnBuilder("plugin_key").setLimit(200).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("plugin_config_key").setLimit(200).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("plugin_key").setLimit(200).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("plugin_config_key").setLimit(200).setIsNullable(true).build())
.addColumn(pluginNameCol)
- .addColumn(newVarcharColumnBuilder("scope").setLimit(20).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("scope").setLimit(20).setIsNullable(false).build())
.addColumn(newClobColumnDefBuilder().setColumnName(DESCRIPTION_COL_NAME).setIsNullable(true).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("priority").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder(STATUS_COL_NAME).setLimit(40).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder(LANGUAGE_COL_NAME).setLimit(20).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("def_remediation_function").setLimit(20).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("def_remediation_gap_mult").setLimit(20).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("def_remediation_base_effort").setLimit(20).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("gap_description").setLimit(MAX_SIZE).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("system_tags").setLimit(MAX_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder(STATUS_COL_NAME).setLimit(40).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder(LANGUAGE_COL_NAME).setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("def_remediation_function").setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("def_remediation_gap_mult").setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("def_remediation_base_effort").setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("gap_description").setLimit(MAX_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("system_tags").setLimit(MAX_SIZE).setIsNullable(true).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_template").setIsNullable(false).setDefaultValue(false).build())
- .addColumn(newVarcharColumnBuilder("description_format").setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("description_format").setLimit(20).setIsNullable(true).build())
.addColumn(new TinyIntColumnDef.Builder().setColumnName("rule_type").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("security_standards").setIsNullable(true).setLimit(4_000).build())
+ .addColumn(newVarcharColumnDefBuilder("security_standards").setIsNullable(true).setLimit(4_000).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_ad_hoc").setIsNullable(false).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_external").setIsNullable(false).build())
.addColumn(NULLABLE_TECHNICAL_CREATED_AT_COL)
.addColumn(NULLABLE_TECHNICAL_UPDATED_AT_COL)
- .addColumn(newVarcharColumnBuilder(TEMPLATE_UUID_COL_NAME).setIsNullable(true).setLimit(UUID_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder(TEMPLATE_UUID_COL_NAME).setIsNullable(true).setLimit(UUID_SIZE).build())
.build());
addIndex(context, "rules", "rules_repo_key", true, pluginRuleKeyCol, pluginNameCol);
}
@@ -1225,18 +1225,18 @@ public class CreateInitialSchema extends DdlChange {
private void createRulesMetadata(Context context) {
String tableName = "rules_metadata";
context.execute(newTableBuilder(tableName)
- .addPkColumn(newVarcharColumnBuilder(RULE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
+ .addPkColumn(newVarcharColumnDefBuilder(RULE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build())
.addColumn(newClobColumnDefBuilder().setColumnName("note_data").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("note_user_uuid").setLimit(USER_UUID_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("note_user_uuid").setLimit(USER_UUID_SIZE).setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("note_created_at").setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("note_updated_at").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("remediation_function").setLimit(20).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("remediation_gap_mult").setLimit(20).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("remediation_base_effort").setLimit(20).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("tags").setLimit(4_000).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("ad_hoc_name").setLimit(200).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("remediation_function").setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("remediation_gap_mult").setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("remediation_base_effort").setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("tags").setLimit(4_000).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("ad_hoc_name").setLimit(200).setIsNullable(true).build())
.addColumn(newClobColumnDefBuilder().setColumnName("ad_hoc_description").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("ad_hoc_severity").setLimit(10).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("ad_hoc_severity").setLimit(10).setIsNullable(true).build())
.addColumn(newTinyIntColumnDefBuilder().setColumnName("ad_hoc_type").setIsNullable(true).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
@@ -1246,15 +1246,15 @@ public class CreateInitialSchema extends DdlChange {
private void createRulesParameters(Context context) {
String tableName = "rules_parameters";
- VarcharColumnDef ruleUuidCol = newVarcharColumnBuilder(RULE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef nameCol = newVarcharColumnBuilder("name").setLimit(128).setIsNullable(false).build();
+ VarcharColumnDef ruleUuidCol = newVarcharColumnDefBuilder(RULE_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef nameCol = newVarcharColumnDefBuilder("name").setLimit(128).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(nameCol)
- .addColumn(newVarcharColumnBuilder(DESCRIPTION_COL_NAME).setLimit(MAX_SIZE).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("param_type").setLimit(512).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("default_value").setLimit(MAX_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder(DESCRIPTION_COL_NAME).setLimit(MAX_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("param_type").setLimit(512).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("default_value").setLimit(MAX_SIZE).setIsNullable(true).build())
.addColumn(ruleUuidCol)
.build());
addIndex(context, tableName, "rules_parameters_rule_uuid", false, ruleUuidCol);
@@ -1266,10 +1266,10 @@ public class CreateInitialSchema extends DdlChange {
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("name").setLimit(100).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder(LANGUAGE_COL_NAME).setLimit(20).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(100).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(LANGUAGE_COL_NAME).setLimit(20).setIsNullable(true).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_built_in").setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("rules_updated_at").setLimit(100).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("rules_updated_at").setLimit(100).setIsNullable(true).build())
.addColumn(DEPRECATED_TECHNICAL_CREATED_AT_COL)
.addColumn(DEPRECATED_TECHNICAL_UPDATED_AT_COL)
.build());
@@ -1277,7 +1277,7 @@ public class CreateInitialSchema extends DdlChange {
private void createSamlMessageIds(Context context) {
String tableName = "saml_message_ids";
- VarcharColumnDef messageIdCol = newVarcharColumnBuilder("message_id").setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef messageIdCol = newVarcharColumnDefBuilder("message_id").setLimit(255).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -1290,21 +1290,21 @@ public class CreateInitialSchema extends DdlChange {
private void createSnapshots(Context context) {
String tableName = "snapshots";
- VarcharColumnDef uuidCol = newVarcharColumnBuilder("uuid").setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef uuidCol = newVarcharColumnDefBuilder("uuid").setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(OLD_UUID_VARCHAR_SIZE).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(uuidCol)
.addColumn(componentUuidCol)
- .addColumn(newVarcharColumnBuilder(STATUS_COL_NAME).setLimit(4).setIsNullable(false).setDefaultValue("U").build())
+ .addColumn(newVarcharColumnDefBuilder(STATUS_COL_NAME).setLimit(4).setIsNullable(false).setDefaultValue("U").build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("islast").setIsNullable(false).setDefaultValue(false).build())
- .addColumn(newVarcharColumnBuilder("version").setLimit(500).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("version").setLimit(500).setIsNullable(true).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("purge_status").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("build_string").setLimit(100).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("revision").setLimit(100).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("build_string").setLimit(100).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("revision").setLimit(100).setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("build_date").setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("period1_mode").setLimit(100).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("period1_param").setLimit(100).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("period1_mode").setLimit(100).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("period1_param").setLimit(100).setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("period1_date").setIsNullable(true).build())
.addColumn(NULLABLE_TECHNICAL_CREATED_AT_COL)
.build());
@@ -1313,13 +1313,13 @@ public class CreateInitialSchema extends DdlChange {
private void createUserProperties(Context context) {
String tableName = "user_properties";
- VarcharColumnDef userUuidCol = newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef keyCol = newVarcharColumnBuilder("kee").setLimit(100).setIsNullable(false).build();
+ VarcharColumnDef userUuidCol = newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef keyCol = newVarcharColumnDefBuilder("kee").setLimit(100).setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(userUuidCol)
.addColumn(keyCol)
- .addColumn(newVarcharColumnBuilder(TEXT_VALUE_COL_NAME).setLimit(4_000).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(TEXT_VALUE_COL_NAME).setLimit(4_000).setIsNullable(false).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(TECHNICAL_UPDATED_AT_COL)
.build());
@@ -1328,12 +1328,12 @@ public class CreateInitialSchema extends DdlChange {
private void createUserRoles(Context context) {
String tableName = "user_roles";
- VarcharColumnDef componentUuidCol = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
- VarcharColumnDef userUuidCol = newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef componentUuidCol = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef userUuidCol = newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(true).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
- .addColumn(newVarcharColumnBuilder("role").setLimit(64).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("role").setLimit(64).setIsNullable(false).build())
.addColumn(componentUuidCol)
.addColumn(userUuidCol)
.build());
@@ -1343,9 +1343,9 @@ public class CreateInitialSchema extends DdlChange {
private void createUserDismissedMessage(Context context) {
String tableName = "user_dismissed_messages";
- VarcharColumnDef userUuidCol = newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef messageTypeCol = newVarcharColumnBuilder("message_type").setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef userUuidCol = newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef messageTypeCol = newVarcharColumnDefBuilder("message_type").setLimit(255).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -1361,9 +1361,9 @@ public class CreateInitialSchema extends DdlChange {
private void createUserTokens(Context context) {
String tableName = "user_tokens";
- VarcharColumnDef userUuidCol = newVarcharColumnBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef nameCol = newVarcharColumnBuilder("name").setLimit(100).setIsNullable(false).build();
- VarcharColumnDef tokenHashCol = newVarcharColumnBuilder("token_hash").setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef userUuidCol = newVarcharColumnDefBuilder(USER_UUID_COL_NAME).setLimit(USER_UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef nameCol = newVarcharColumnDefBuilder("name").setLimit(100).setIsNullable(false).build();
+ VarcharColumnDef tokenHashCol = newVarcharColumnDefBuilder("token_hash").setLimit(255).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
.addPkColumn(UUID_COL)
@@ -1379,29 +1379,29 @@ public class CreateInitialSchema extends DdlChange {
private void createUsers(Context context) {
String tableName = "users";
- VarcharColumnDef loginCol = newVarcharColumnBuilder("login").setLimit(255).setIsNullable(false).build();
- VarcharColumnDef externalLoginCol = newVarcharColumnBuilder("external_login").setLimit(255).setIsNullable(false).build();
- VarcharColumnDef externalIdentityProviderCol = newVarcharColumnBuilder("external_identity_provider").setLimit(100).setIsNullable(false).build();
- VarcharColumnDef externalIdCol = newVarcharColumnBuilder("external_id").setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef loginCol = newVarcharColumnDefBuilder("login").setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef externalLoginCol = newVarcharColumnDefBuilder("external_login").setLimit(255).setIsNullable(false).build();
+ VarcharColumnDef externalIdentityProviderCol = newVarcharColumnDefBuilder("external_identity_provider").setLimit(100).setIsNullable(false).build();
+ VarcharColumnDef externalIdCol = newVarcharColumnDefBuilder("external_id").setLimit(255).setIsNullable(false).build();
context.execute(
newTableBuilder(tableName)
- .addPkColumn(newVarcharColumnBuilder("uuid").setLimit(USER_UUID_SIZE).setIsNullable(false).build())
+ .addPkColumn(newVarcharColumnDefBuilder("uuid").setLimit(USER_UUID_SIZE).setIsNullable(false).build())
.addColumn(loginCol)
- .addColumn(newVarcharColumnBuilder("name").setLimit(200).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("email").setLimit(100).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("crypted_password").setLimit(100).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("salt").setLimit(40).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("hash_method").setLimit(10).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(200).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("email").setLimit(100).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("crypted_password").setLimit(100).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("salt").setLimit(40).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("hash_method").setLimit(10).setIsNullable(true).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("active").setDefaultValue(true).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("scm_accounts").setLimit(MAX_SIZE).build())
+ .addColumn(newVarcharColumnDefBuilder("scm_accounts").setLimit(MAX_SIZE).build())
.addColumn(externalLoginCol)
.addColumn(externalIdentityProviderCol)
.addColumn(externalIdCol)
.addColumn(newBooleanColumnDefBuilder().setColumnName("is_root").setIsNullable(false).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("user_local").setIsNullable(true).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("onboarded").setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("homepage_type").setLimit(40).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("homepage_parameter").setLimit(40).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("homepage_type").setLimit(40).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("homepage_parameter").setLimit(40).setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("last_connection_date").setIsNullable(true).build())
.addColumn(NULLABLE_TECHNICAL_CREATED_AT_COL)
.addColumn(NULLABLE_TECHNICAL_UPDATED_AT_COL)
@@ -1416,17 +1416,17 @@ public class CreateInitialSchema extends DdlChange {
private void createWebhookDeliveries(Context context) {
String tableName = "webhook_deliveries";
- VarcharColumnDef componentUuidColumn = newVarcharColumnBuilder(COMPONENT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
- VarcharColumnDef ceTaskUuidColumn = newVarcharColumnBuilder("ce_task_uuid").setLimit(UUID_SIZE).setIsNullable(true).build();
- VarcharColumnDef webhookUuidColumn = newVarcharColumnBuilder("webhook_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef componentUuidColumn = newVarcharColumnDefBuilder(COMPONENT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(false).build();
+ VarcharColumnDef ceTaskUuidColumn = newVarcharColumnDefBuilder("ce_task_uuid").setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef webhookUuidColumn = newVarcharColumnDefBuilder("webhook_uuid").setLimit(UUID_SIZE).setIsNullable(false).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(webhookUuidColumn)
.addColumn(componentUuidColumn)
.addColumn(ceTaskUuidColumn)
- .addColumn(newVarcharColumnBuilder(ANALYSIS_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build())
- .addColumn(newVarcharColumnBuilder("name").setLimit(100).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("url").setLimit(2_000).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder(ANALYSIS_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(100).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("url").setLimit(2_000).setIsNullable(false).build())
.addColumn(newBooleanColumnDefBuilder().setColumnName("success").setIsNullable(false).build())
.addColumn(newIntegerColumnDefBuilder().setColumnName("http_status").setIsNullable(true).build())
.addColumn(newBigIntegerColumnDefBuilder().setColumnName("duration_ms").setIsNullable(false).build())
@@ -1441,13 +1441,13 @@ public class CreateInitialSchema extends DdlChange {
private void createWebhooks(Context context) {
String tableName = "webhooks";
- VarcharColumnDef projectUuidCol = newVarcharColumnBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
+ VarcharColumnDef projectUuidCol = newVarcharColumnDefBuilder(PROJECT_UUID_COL_NAME).setLimit(UUID_SIZE).setIsNullable(true).build();
context.execute(newTableBuilder(tableName)
.addPkColumn(UUID_COL)
.addColumn(projectUuidCol)
- .addColumn(newVarcharColumnBuilder("name").setLimit(100).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("url").setLimit(2_000).setIsNullable(false).build())
- .addColumn(newVarcharColumnBuilder("secret").setLimit(200).setIsNullable(true).build())
+ .addColumn(newVarcharColumnDefBuilder("name").setLimit(100).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("url").setLimit(2_000).setIsNullable(false).build())
+ .addColumn(newVarcharColumnDefBuilder("secret").setLimit(200).setIsNullable(true).build())
.addColumn(TECHNICAL_CREATED_AT_COL)
.addColumn(NULLABLE_TECHNICAL_UPDATED_AT_COL)
.build());
@@ -1462,13 +1462,7 @@ public class CreateInitialSchema extends DdlChange {
context.execute(builder.build());
}
- public static VarcharColumnDef.Builder newVarcharColumnBuilder(String column) {
- return newVarcharColumnDefBuilder().setColumnName(column);
- }
- private static BooleanColumnDef.Builder newBooleanColumnBuilder(String column) {
- return newBooleanColumnDefBuilder().setColumnName(column);
- }
private CreateTableBuilder newTableBuilder(String tableName) {
return new CreateTableBuilder(getDialect(), tableName);
diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/AddRulesMetadataColumnsToRulesTable.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/AddRulesMetadataColumnsToRulesTable.java
index 5f0d75874a3..c5b7be9c312 100644
--- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/AddRulesMetadataColumnsToRulesTable.java
+++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/AddRulesMetadataColumnsToRulesTable.java
@@ -23,6 +23,11 @@ import java.sql.Connection;
import java.sql.SQLException;
import org.sonar.db.Database;
import org.sonar.db.DatabaseUtils;
+import org.sonar.server.platform.db.migration.def.BigIntegerColumnDef;
+import org.sonar.server.platform.db.migration.def.ClobColumnDef;
+import org.sonar.server.platform.db.migration.def.ColumnDef;
+import org.sonar.server.platform.db.migration.def.TinyIntColumnDef;
+import org.sonar.server.platform.db.migration.def.VarcharColumnDef;
import org.sonar.server.platform.db.migration.sql.AddColumnsBuilder;
import org.sonar.server.platform.db.migration.step.DdlChange;
@@ -30,7 +35,7 @@ import static org.sonar.server.platform.db.migration.def.BigIntegerColumnDef.new
import static org.sonar.server.platform.db.migration.def.ClobColumnDef.newClobColumnDefBuilder;
import static org.sonar.server.platform.db.migration.def.TinyIntColumnDef.newTinyIntColumnDefBuilder;
import static org.sonar.server.platform.db.migration.def.VarcharColumnDef.USER_UUID_SIZE;
-import static org.sonar.server.platform.db.migration.version.v00.CreateInitialSchema.newVarcharColumnBuilder;
+import static org.sonar.server.platform.db.migration.def.VarcharColumnDef.newVarcharColumnDefBuilder;
public class AddRulesMetadataColumnsToRulesTable extends DdlChange {
@@ -60,98 +65,75 @@ public class AddRulesMetadataColumnsToRulesTable extends DdlChange {
}
private void createAdHocType(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "ad_hoc_type")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newTinyIntColumnDefBuilder().setColumnName("ad_hoc_type").setIsNullable(true).build())
- .build());
- }
+ TinyIntColumnDef adHocTypeColumnDef = newTinyIntColumnDefBuilder().setColumnName("ad_hoc_type").setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, adHocTypeColumnDef);
}
private void createAdHocSeverity(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "ad_hoc_severity")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newVarcharColumnBuilder("ad_hoc_severity").setLimit(10).setIsNullable(true).build())
- .build());
- }
+ VarcharColumnDef adHocSeverityColumnDef = newVarcharColumnDefBuilder("ad_hoc_severity").setLimit(10).setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, adHocSeverityColumnDef);
+
}
private void createAdHocDescription(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "ad_hoc_description")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newClobColumnDefBuilder().setColumnName("ad_hoc_description").setIsNullable(true).build())
- .build());
- }
+ ClobColumnDef adHocDescriptionColumnDef = newClobColumnDefBuilder().setColumnName("ad_hoc_description").setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, adHocDescriptionColumnDef);
}
private void createAdHocName(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "ad_hoc_name")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newVarcharColumnBuilder("ad_hoc_name").setLimit(200).setIsNullable(true).build())
- .build());
- }
+ VarcharColumnDef adHocNameColumnDef = newVarcharColumnDefBuilder("ad_hoc_name").setLimit(200).setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, adHocNameColumnDef);
}
private void createTags(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "tags")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newVarcharColumnBuilder("tags").setLimit(4_000).setIsNullable(true).build())
- .build());
- }
+ VarcharColumnDef tagsColumnDef = newVarcharColumnDefBuilder("tags").setLimit(4_000).setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, tagsColumnDef);
+
}
private void createRemediationBaseEffort(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "remediation_base_effort")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newVarcharColumnBuilder("remediation_base_effort").setLimit(20).setIsNullable(true).build())
- .build());
- }
+ VarcharColumnDef remediationBaseEffortColumnDef = newVarcharColumnDefBuilder("remediation_base_effort").setLimit(20).setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, remediationBaseEffortColumnDef);
+
}
private void createRemediationGapMult(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "remediation_gap_mult")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newVarcharColumnBuilder("remediation_gap_mult").setLimit(20).setIsNullable(true).build())
- .build());
- }
+ VarcharColumnDef remediationGapMultColumnDef = newVarcharColumnDefBuilder("remediation_gap_mult").setLimit(20).setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, remediationGapMultColumnDef);
}
private void createRemediationFunction(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "remediation_function")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newVarcharColumnBuilder("remediation_function").setLimit(20).setIsNullable(true).build())
- .build());
- }
+ VarcharColumnDef remediateFunctionColumnDef = newVarcharColumnDefBuilder("remediation_function").setLimit(20).setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, remediateFunctionColumnDef);
}
private void createNoteUpdatedAt(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "note_updated_at")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newBigIntegerColumnDefBuilder().setColumnName("note_updated_at").setIsNullable(true).build())
- .build());
- }
+ BigIntegerColumnDef noteUpdatedAtColumnDef = newBigIntegerColumnDefBuilder().setColumnName("note_updated_at").setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, noteUpdatedAtColumnDef);
+
}
private void createNoteCreatedAt(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "note_created_at")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newBigIntegerColumnDefBuilder().setColumnName("note_created_at").setIsNullable(true).build())
- .build());
- }
+ BigIntegerColumnDef noteCreatedAtColumnDef = newBigIntegerColumnDefBuilder().setColumnName("note_created_at").setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, noteCreatedAtColumnDef);
}
private void createNoteUserUuid(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "note_user_uuid")) {
- context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newVarcharColumnBuilder("note_user_uuid").setLimit(USER_UUID_SIZE).setIsNullable(true).build())
- .build());
- }
+ VarcharColumnDef noteUserUuidColumnDef = newVarcharColumnDefBuilder("note_user_uuid").setLimit(USER_UUID_SIZE).setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, noteUserUuidColumnDef);
}
private void createNoteDataAt(Context context, Connection connection) {
- if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, "note_data")) {
+ ClobColumnDef noteDataColumnDef = newClobColumnDefBuilder().setColumnName("note_data").setIsNullable(true).build();
+ createColumnIfNotExists(context, connection, noteDataColumnDef);
+ }
+
+ private void createColumnIfNotExists(Context context, Connection connection, ColumnDef columnDef) {
+ if (!DatabaseUtils.tableColumnExists(connection, TABLE_NAME, columnDef.getName())) {
context.execute(new AddColumnsBuilder(getDialect(), TABLE_NAME)
- .addColumn(newClobColumnDefBuilder().setColumnName("note_data").setIsNullable(true).build())
+ .addColumn(columnDef)
.build());
}
}
+
}
diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/DbVersion95.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/DbVersion95.java
index 014a6819a37..45271f2d98a 100644
--- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/DbVersion95.java
+++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/DbVersion95.java
@@ -39,6 +39,7 @@ public class DbVersion95 implements DbVersion {
.add(6411, "Overwrite plugin file hash to force reloading rules", OverwritePluginFileHash.class)
.add(6412, "Add rules_metadata columns to rules table", AddRulesMetadataColumnsToRulesTable.class)
+ .add(6413, "Populate rules metadata in rules table", PopulateRulesMetadataInRuleTable.class)
;
}
}
diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTable.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTable.java
new file mode 100644
index 00000000000..9a91efd1e78
--- /dev/null
+++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTable.java
@@ -0,0 +1,72 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2022 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.server.platform.db.migration.version.v95;
+
+import java.sql.SQLException;
+import org.sonar.db.Database;
+import org.sonar.db.DatabaseUtils;
+import org.sonar.server.platform.db.migration.step.DataChange;
+import org.sonar.server.platform.db.migration.step.MassUpdate;
+
+public class PopulateRulesMetadataInRuleTable extends DataChange {
+
+ private static final String RULES_METADATA_TABLE_NAME = "rules_metadata";
+
+ public PopulateRulesMetadataInRuleTable(Database db) {
+ super(db);
+ }
+
+ @Override
+ protected void execute(Context context) throws SQLException {
+ if (ruleMetadataTableExists()) {
+ MassUpdate massUpdate = context.prepareMassUpdate();
+ massUpdate.select("select note_data, note_user_uuid, note_created_at, note_updated_at, remediation_function," +
+ " remediation_gap_mult, remediation_base_effort, tags, ad_hoc_name, ad_hoc_description, ad_hoc_severity, ad_hoc_type, rule_uuid from rules_metadata");
+
+ massUpdate.update("update rules set note_data = ?, note_user_uuid = ?, note_created_at = ?," +
+ " note_updated_at = ?, remediation_function = ?, remediation_gap_mult = ?, remediation_base_effort = ?," +
+ " tags = ?, ad_hoc_name = ?, ad_hoc_description = ?, ad_hoc_severity = ?, ad_hoc_type = ? where uuid = ?");
+
+ massUpdate.execute((row, update) -> {
+ update.setBytes(1, row.getBytes(1)); // note_data
+ update.setString(2, row.getString(2)); // note_user_uuid
+ update.setLong(3, row.getLong(3)); // note_created_at
+ update.setLong(4, row.getLong(4)); // note_updated_at
+ update.setString(5, row.getString(5)); // remediation_function
+ update.setString(6, row.getString(6)); // remediation_gap_mult
+ update.setString(7, row.getString(7)); // remediation_base_effort
+ update.setString(8, row.getString(8)); // tags
+ update.setString(9, row.getString(9)); // ad_hoc_name
+ update.setString(10, row.getString(10)); // ad_hoc_description
+ update.setString(11, row.getString(11)); // ad_hoc_severity
+ update.setInt(12, row.getInt(12)); // ad_hoc_type
+ update.setString(13, row.getString(13)); // where clause (rule uuid)
+
+ return true;
+ });
+ }
+ }
+
+ private boolean ruleMetadataTableExists() throws SQLException {
+ try (var connection = getDatabase().getDataSource().getConnection()) {
+ return DatabaseUtils.tableExists(RULES_METADATA_TABLE_NAME, connection);
+ }
+ }
+}
diff --git a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTableTest.java b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTableTest.java
new file mode 100644
index 00000000000..5c25978f1a1
--- /dev/null
+++ b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTableTest.java
@@ -0,0 +1,139 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2022 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.server.platform.db.migration.version.v95;
+
+import java.sql.SQLException;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import org.apache.commons.lang.RandomStringUtils;
+import org.apache.commons.lang.math.RandomUtils;
+import org.assertj.core.api.Assertions;
+import org.junit.Rule;
+import org.junit.Test;
+import org.sonar.db.CoreDbTester;
+import org.sonar.server.platform.db.migration.step.DataChange;
+
+import static org.apache.commons.lang.RandomStringUtils.randomAlphanumeric;
+import static org.apache.commons.lang.math.RandomUtils.nextBoolean;
+
+public class PopulateRulesMetadataInRuleTableTest {
+
+ @Rule
+ public final CoreDbTester db = CoreDbTester.createForSchema(PopulateRulesMetadataInRuleTableTest.class, "schema.sql");
+
+ private final DataChange underTest = new PopulateRulesMetadataInRuleTable(db.database());
+
+ @Test
+ public void validate_metadata_are_migrated_to_rules() throws SQLException {
+ // create rules
+ String ruleUuid1 = insertRule();
+ String ruleUuid2 = insertRule();
+ String ruleUuid3 = insertRule();
+
+ // create metadata
+ Map<String, Object> rule1Metadata = insertRuleMetadata(ruleUuid1);
+ Map<String, Object> rule2Metadata = insertRuleMetadata(ruleUuid2);
+ insertRuleMetadata("non-existing-rule");
+
+ // migrate
+ underTest.execute();
+
+ // verify result
+ verifyRuleMetadata(db, ruleUuid1, rule1Metadata);
+ verifyRuleMetadata(db, ruleUuid2, rule2Metadata);
+ verifyNoRuleMetadata(ruleUuid3);
+ }
+
+ private void verifyNoRuleMetadata(String ruleUuid) {
+ Map<String, Object> mapRule = db.selectFirst(String.format("select * from rules where uuid='%s'", ruleUuid));
+ List<String> metadataColumns = List.of("RULE_UUID", "NOTE_DATA", "NOTE_USER_UUID", "NOTE_CREATED_AT", "NOTE_UPDATED_AT", "REMEDIATION_FUNCTION", "REMEDIATION_GAP_MULT", "REMEDIATION_BASE_EFFORT", "TAGS", "AD_HOC_NAME", "AD_HOC_DESCRIPTION", "AD_HOC_SEVERITY", "AD_HOC_TYPE");
+ for (String key : metadataColumns) {
+ Assertions.assertThat(mapRule.get(key)).isNull();
+ }
+ }
+
+ private void verifyRuleMetadata(CoreDbTester db, String ruleUuid, Map<String, Object> ruleMetadata) {
+ // check rule metadata are here
+ Map<String, Object> mapRule = db.selectFirst(String.format("select * from rules where uuid='%s'", ruleUuid));
+ Map<String, Object> mapToVerify = new HashMap<>(ruleMetadata);
+ mapToVerify.remove("RULE_UUID");
+ Assertions.assertThat(mapRule)
+ .containsAllEntriesOf(mapToVerify);
+ }
+
+ @Test
+ public void migration_is_reentrant() throws SQLException {
+ // create rules
+ String ruleUuid1 = insertRule();
+ String ruleUuid2 = insertRule();
+ String ruleUuid3 = insertRule();
+
+ // create metadata
+ Map<String, Object> rule1Metadata = insertRuleMetadata(ruleUuid1);
+ Map<String, Object> rule2Metadata = insertRuleMetadata(ruleUuid2);
+ insertRuleMetadata("non-existing-rule");
+
+ underTest.execute();
+ underTest.execute();
+
+ // verify result
+ verifyRuleMetadata(db, ruleUuid1, rule1Metadata);
+ verifyRuleMetadata(db, ruleUuid2, rule2Metadata);
+ verifyNoRuleMetadata(ruleUuid3);
+ }
+
+ private String insertRule() {
+ String ruleUuid = RandomStringUtils.randomAlphanumeric(40);
+ Map<String, Object> map = new HashMap<>();
+ map.put("uuid", ruleUuid);
+ map.put("plugin_rule_key", randomAlphanumeric(20));
+ map.put("plugin_name", randomAlphanumeric(20));
+ map.put("scope", randomAlphanumeric(20));
+ map.put("is_template", nextBoolean());
+ map.put("is_ad_hoc", nextBoolean());
+ map.put("is_external", nextBoolean());
+ db.executeInsert("rules", map);
+ return ruleUuid;
+ }
+
+ private Map<String, Object> insertRuleMetadata(String ruleUuid) {
+ Map<String, Object> map = new HashMap<>();
+ map.put("RULE_UUID", ruleUuid);
+ map.put("NOTE_DATA", randomAlphanumeric(20));
+ map.put("NOTE_USER_UUID", randomAlphanumeric(20));
+ map.put("NOTE_CREATED_AT", System.currentTimeMillis());
+ map.put("NOTE_UPDATED_AT", System.currentTimeMillis());
+ map.put("REMEDIATION_FUNCTION", randomAlphanumeric(20));
+ map.put("REMEDIATION_GAP_MULT", randomAlphanumeric(20));
+ map.put("REMEDIATION_BASE_EFFORT", randomAlphanumeric(20));
+ map.put("TAGS", randomAlphanumeric(20));
+ map.put("AD_HOC_NAME", randomAlphanumeric(20));
+ map.put("AD_HOC_DESCRIPTION", randomAlphanumeric(1000000));
+ map.put("AD_HOC_SEVERITY", randomAlphanumeric(10));
+ map.put("AD_HOC_TYPE", (long) RandomUtils.nextInt(10));
+ db.executeInsert("rules_metadata", map);
+ return map;
+
+ }
+
+
+
+}
diff --git a/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTableTest/schema.sql b/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTableTest/schema.sql
new file mode 100644
index 00000000000..453c143a4c6
--- /dev/null
+++ b/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v95/PopulateRulesMetadataInRuleTableTest/schema.sql
@@ -0,0 +1,57 @@
+CREATE TABLE "RULES"(
+ "UUID" CHARACTER VARYING(40) NOT NULL,
+ "NAME" CHARACTER VARYING(200),
+ "PLUGIN_RULE_KEY" CHARACTER VARYING(200) NOT NULL,
+ "PLUGIN_KEY" CHARACTER VARYING(200),
+ "PLUGIN_CONFIG_KEY" CHARACTER VARYING(200),
+ "PLUGIN_NAME" CHARACTER VARYING(255) NOT NULL,
+ "SCOPE" CHARACTER VARYING(20) NOT NULL,
+ "PRIORITY" INTEGER,
+ "STATUS" CHARACTER VARYING(40),
+ "LANGUAGE" CHARACTER VARYING(20),
+ "DEF_REMEDIATION_FUNCTION" CHARACTER VARYING(20),
+ "DEF_REMEDIATION_GAP_MULT" CHARACTER VARYING(20),
+ "DEF_REMEDIATION_BASE_EFFORT" CHARACTER VARYING(20),
+ "GAP_DESCRIPTION" CHARACTER VARYING(4000),
+ "SYSTEM_TAGS" CHARACTER VARYING(4000),
+ "IS_TEMPLATE" BOOLEAN DEFAULT FALSE NOT NULL,
+ "DESCRIPTION_FORMAT" CHARACTER VARYING(20),
+ "RULE_TYPE" TINYINT,
+ "SECURITY_STANDARDS" CHARACTER VARYING(4000),
+ "IS_AD_HOC" BOOLEAN NOT NULL,
+ "IS_EXTERNAL" BOOLEAN NOT NULL,
+ "CREATED_AT" BIGINT,
+ "UPDATED_AT" BIGINT,
+ "TEMPLATE_UUID" CHARACTER VARYING(40),
+ "NOTE_DATA" CHARACTER LARGE OBJECT,
+ "NOTE_USER_UUID" CHARACTER VARYING(255),
+ "NOTE_CREATED_AT" BIGINT,
+ "NOTE_UPDATED_AT" BIGINT,
+ "REMEDIATION_FUNCTION" CHARACTER VARYING(20),
+ "REMEDIATION_GAP_MULT" CHARACTER VARYING(20),
+ "REMEDIATION_BASE_EFFORT" CHARACTER VARYING(20),
+ "TAGS" CHARACTER VARYING(4000),
+ "AD_HOC_NAME" CHARACTER VARYING(200),
+ "AD_HOC_DESCRIPTION" CHARACTER LARGE OBJECT,
+ "AD_HOC_SEVERITY" CHARACTER VARYING(10),
+ "AD_HOC_TYPE" TINYINT
+);
+ALTER TABLE "RULES" ADD CONSTRAINT "PK_RULES" PRIMARY KEY("UUID");
+CREATE UNIQUE INDEX "RULES_REPO_KEY" ON "RULES"("PLUGIN_RULE_KEY" NULLS FIRST, "PLUGIN_NAME" NULLS FIRST);
+
+CREATE TABLE "RULES_METADATA"(
+ "RULE_UUID" CHARACTER VARYING(40) NOT NULL,
+ "NOTE_DATA" CHARACTER LARGE OBJECT,
+ "NOTE_USER_UUID" CHARACTER VARYING(255),
+ "NOTE_CREATED_AT" BIGINT,
+ "NOTE_UPDATED_AT" BIGINT,
+ "REMEDIATION_FUNCTION" CHARACTER VARYING(20),
+ "REMEDIATION_GAP_MULT" CHARACTER VARYING(20),
+ "REMEDIATION_BASE_EFFORT" CHARACTER VARYING(20),
+ "TAGS" CHARACTER VARYING(4000),
+ "AD_HOC_NAME" CHARACTER VARYING(200),
+ "AD_HOC_DESCRIPTION" CHARACTER LARGE OBJECT,
+ "AD_HOC_SEVERITY" CHARACTER VARYING(10),
+ "AD_HOC_TYPE" TINYINT
+);
+ALTER TABLE "RULES_METADATA" ADD CONSTRAINT "PK_RULES_METADATA" PRIMARY KEY("RULE_UUID");