From 1f79079c36a1b7e2edcba2188dbe238a60a36d9d Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Wed, 17 Jul 2024 12:44:42 +0300 Subject: [PATCH 1/9] HCK-7186: add config for schema tags --- .../container_level/containerLevelConfig.json | 79 +++++++++++++++++++ 1 file changed, 79 insertions(+) diff --git a/properties_pane/container_level/containerLevelConfig.json b/properties_pane/container_level/containerLevelConfig.json index 24fb17f6..414e7738 100644 --- a/properties_pane/container_level/containerLevelConfig.json +++ b/properties_pane/container_level/containerLevelConfig.json @@ -156,6 +156,29 @@ making sure that you maintain a proper JSON format. "minValue": 0, "maxValue": 90 }, + { + "propertyName": "Schema Tags", + "propertyKeyword": "schemaTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -917,5 +940,61 @@ making sure that you maintain a proper JSON format. ] } ] + }, + { + "lowerTab": "Tags", + "structure": [ + { + "propertyName": "Tag", + "propertyType": "group", + "propertyKeyword": "tags", + "propertyTooltip": "Creates a new stored tag or replaces an existing tag for the current database.", + "structure": [ + { + "propertyName": "Name", + "propertyKeyword": "name", + "propertyTooltip": "The name of the tag.", + "propertyType": "text", + "validation": { + "required": true + } + }, + { + "propertyName": "Or replace", + "propertyKeyword": "orReplace", + "propertyType": "checkbox", + "propertyTooltip": "Specifies that if a tag with the same name as this one already exists, the existing tag is replaced. You can only replace a tag with a new tag." + }, + { + "propertyName": "If not exist", + "propertyKeyword": "ifNotExist", + "propertyType": "checkbox" + }, + { + "propertyName": "Allowed values", + "propertyKeyword": "allowedValues", + "propertyType": "group", + "parentType": "tags", + "structure": [ + { + "propertyName": "Value", + "propertyKeyword": "value", + "propertyTooltip": "", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, + { + "propertyName": "Comment", + "propertyKeyword": "description", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + } + ] } ] From adc58f7245b8a957949b49cbb4f75c70d7b10242 Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Wed, 17 Jul 2024 12:45:21 +0300 Subject: [PATCH 2/9] HCK-7186: add ddl generating for tags --- forward_engineering/configs/templates.js | 3 +- forward_engineering/ddlProvider.js | 35 +++++++++++++++++-- forward_engineering/helpers/tagHelper.js | 43 ++++++++++++++++++++++++ 3 files changed, 78 insertions(+), 3 deletions(-) create mode 100644 forward_engineering/helpers/tagHelper.js diff --git a/forward_engineering/configs/templates.js b/forward_engineering/configs/templates.js index 5ea4b336..5c392728 100644 --- a/forward_engineering/configs/templates.js +++ b/forward_engineering/configs/templates.js @@ -1,7 +1,7 @@ module.exports = { createDatabase: 'CREATE DATABASE IF NOT EXISTS ${name};\nUSE DATABASE ${name};\n', createSchema: - 'CREATE${transient} SCHEMA IF NOT EXISTS ${name}${managed_access}${data_retention}${comment};\nUSE SCHEMA ${name};\n', + 'CREATE${transient} SCHEMA IF NOT EXISTS ${name}${managed_access}${data_retention}${comment}${tag};\nUSE SCHEMA ${name};\n', createTable: 'CREATE${temporary}${transient} TABLE IF NOT EXISTS\n' + '\t${name} (\n' + @@ -48,4 +48,5 @@ module.exports = { setPropertyTable: 'SET ${property};\n', alterViewScript: 'ALTER VIEW IF EXISTS ${name} ', alterMaterializedViewScript: 'ALTER MATERIALIZED VIEW ${name} ', + createTag: 'CREATE${orReplace} TAG${ifNotExist} ${name}${allowedValues}${comment};\n', }; diff --git a/forward_engineering/ddlProvider.js b/forward_engineering/ddlProvider.js index ed319b30..08f47d3f 100644 --- a/forward_engineering/ddlProvider.js +++ b/forward_engineering/ddlProvider.js @@ -64,6 +64,8 @@ module.exports = (baseProvider, options, app) => { tab, }); + const { getTagStatement, getTagAllowedValues } = require('./helpers/tagHelper')({ getName, toString }); + const getOutOfLineConstraints = ( foreignKeyConstraints, primaryKeyConstraints, @@ -95,6 +97,8 @@ module.exports = (baseProvider, options, app) => { fileFormats, stages, isCaseSensitive, + tags, + schemaTags, }) { const transientStatement = transient ? ' TRANSIENT' : ''; const dataRetentionStatement = @@ -104,12 +108,14 @@ module.exports = (baseProvider, options, app) => { const currentSchemaName = getName(isCaseSensitive, schemaName); const currentDatabaseName = getName(isCaseSensitive, databaseName); const fullName = getFullName(currentDatabaseName, currentSchemaName); + const tagStatement = getTagStatement({ tags: schemaTags, isCaseSensitive, indent: '\n\t' }); const schemaStatement = assignTemplates(templates.createSchema, { name: fullName, transient: transientStatement, managed_access: managedAccessStatement, data_retention: dataRetentionStatement, comment: commentStatement, + tag: tagStatement, }); const getParameters = payload => { @@ -137,6 +143,7 @@ module.exports = (baseProvider, options, app) => { const getBodyStatement = body => (body ? `\n\t$$\n${body}\n\t$$` : ''); const getCommentsStatement = text => (text ? `\n\tCOMMENT = '${text}'` : ''); const getNotNullStatement = isEnabled => (isEnabled ? '\n\tNOT NULL' : ''); + const getIfNotExistStatement = ifNotExist => (ifNotExist ? ' IF NOT EXISTS' : ''); const userDefinedFunctions = udfs.map(udf => assignTemplates(templates.createUDF, { @@ -209,6 +216,16 @@ module.exports = (baseProvider, options, app) => { }), ); + const tagsStatements = tags.map(tag => + assignTemplates(templates.createTag, { + orReplace: getOrReplaceStatement(tag.orReplace), + ifNotExist: getIfNotExistStatement(tag.ifNotExist), + allowedValues: getTagAllowedValues(tag.allowedValues), + name: getName(isCaseSensitive, tag.name), + comment: getCommentsStatement(tag.description), + }), + ); + const statements = []; if (databaseName) { @@ -216,7 +233,7 @@ module.exports = (baseProvider, options, app) => { assignTemplates(templates.createDatabase, { name: getName(isCaseSensitive, databaseName) }), ); } - + statements.push(...tagsStatements); statements.push(schemaStatement); return [ @@ -528,7 +545,7 @@ module.exports = (baseProvider, options, app) => { }); }, - hydrateSchema(containerData, { udfs, procedures, sequences, fileFormats, stages } = {}) { + hydrateSchema(containerData, { udfs, procedures, sequences, fileFormats, stages, tags } = {}) { return { schemaName: getName(containerData.isCaseSensitive, containerData.name), isCaseSensitive: containerData.isCaseSensitive, @@ -537,6 +554,7 @@ module.exports = (baseProvider, options, app) => { transient: containerData.transient, managedAccess: containerData.managedAccess, dataRetention: containerData.DATA_RETENTION_TIME_IN_DAYS, + schemaTags: containerData.schemaTags, udfs: Array.isArray(udfs) ? udfs .map(udf => @@ -625,6 +643,19 @@ module.exports = (baseProvider, options, app) => { ) .filter(stage => stage.name) : [], + tags: Array.isArray(tags) + ? tags + .map(tag => + clean({ + name: tag.name || undefined, + orReplace: tag.orReplace || undefined, + ifNotExist: tag.ifNotExist || undefined, + allowedValues: tag.allowedValues || undefined, + description: tag.description || undefined, + }), + ) + .filter(tag => tag.name) + : [], }; }, diff --git a/forward_engineering/helpers/tagHelper.js b/forward_engineering/helpers/tagHelper.js new file mode 100644 index 00000000..5accca4e --- /dev/null +++ b/forward_engineering/helpers/tagHelper.js @@ -0,0 +1,43 @@ +/** + * @typedef {{ id: string, tagName?: string, tagValue?: string }} Tag + */ + +const { isEmpty } = require('lodash'); + +module.exports = ({ getName, toString }) => { + /** + * @param {{ tags: Tag[], isCaseSensitive: boolean, indent: string }} + * @returns {string} + */ + const getTagStatement = ({ tags, isCaseSensitive, indent }) => { + if (isEmpty(tags)) { + return ''; + } + + const tagStatements = tags + .filter(tag => tag.tagName) + .map(tag => `${getName(isCaseSensitive, tag.tagName)} = ${toString(tag.tagValue)}`) + .join(', '); + + return `${indent}WITH TAG ${tagStatements}`; + }; + + /** + * @param {string[]} allowedValues + * @returns {string} + */ + const getTagAllowedValues = allowedValues => { + if (isEmpty(allowedValues)) { + return ''; + } + + const values = allowedValues.map(({ value }) => toString(value)).join(', '); + + return ` ALLOWED_VALUES ${values}`; + }; + + return { + getTagStatement, + getTagAllowedValues, + }; +}; From c9f734ae46ce9042bd581d4984066c5996ce8a72 Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Wed, 17 Jul 2024 14:10:58 +0300 Subject: [PATCH 3/9] HCK-7186: add ddl generation for table tags --- forward_engineering/ddlProvider.js | 24 +++++++++++++++---- forward_engineering/helpers/tagHelper.js | 4 ++-- .../entity_level/entityLevelConfig.json | 23 ++++++++++++++++++ 3 files changed, 44 insertions(+), 7 deletions(-) diff --git a/forward_engineering/ddlProvider.js b/forward_engineering/ddlProvider.js index 08f47d3f..8ed08541 100644 --- a/forward_engineering/ddlProvider.js +++ b/forward_engineering/ddlProvider.js @@ -302,24 +302,28 @@ module.exports = (baseProvider, options, app) => { const columnDefinitions = tableData.columns .map(column => commentIfDeactivated(column.statement, column)) .join(',\n\t\t'); + const tagsStatement = getTagStatement({ + tags: tableData.tableTags, + isCaseSensitive: tableData.isCaseSensitive, + }); if (tableData.selectStatement) { return assignTemplates(templates.createAsSelect, { name: tableData.fullName, selectStatement: tableData.selectStatement, - tableOptions: addOptions([clusterKeys, copyGrants]), + tableOptions: addOptions([clusterKeys, copyGrants, tagsStatement]), }); } else if (tableData.cloneTableName) { return assignTemplates(templates.createCloneTable, { name: tableData.fullName, source_table: getFullName(schemaName, tableData.cloneTableName), - tableOptions: addOptions([atOrBefore, copyGrants]), + tableOptions: addOptions([atOrBefore, copyGrants, tagsStatement]), }); } else if (tableData.likeTableName) { return assignTemplates(templates.createLikeTable, { name: tableData.fullName, source_table: getFullName(schemaName, tableData.likeTableName), - tableOptions: addOptions([clusterKeys, copyGrants]), + tableOptions: addOptions([clusterKeys, copyGrants, tagsStatement]), }); } else if (tableData.external) { const location = tableData.externalOptions.location @@ -338,7 +342,16 @@ module.exports = (baseProvider, options, app) => { return assignTemplates(templates.createExternalTable, { name: tableData.fullName, tableOptions: addOptions( - [partitionKeys, fileFormat, location, refreshOnCreate, autoRefresh, pattern, copyGrants], + [ + partitionKeys, + fileFormat, + location, + refreshOnCreate, + autoRefresh, + pattern, + copyGrants, + tagsStatement, + ], comment, ), @@ -356,7 +369,7 @@ module.exports = (baseProvider, options, app) => { temporary: temporary, transient: transient, tableOptions: addOptions( - [clusterKeys, stageFileFormat, copyOptions, dataRetentionTime, copyGrants], + [clusterKeys, stageFileFormat, copyOptions, dataRetentionTime, copyGrants, tagsStatement], comment, ), @@ -803,6 +816,7 @@ module.exports = (baseProvider, options, app) => { isCaseSensitive: firstTab.isCaseSensitive, }), ), + tableTags: firstTab.tableTags ?? [], }; }, diff --git a/forward_engineering/helpers/tagHelper.js b/forward_engineering/helpers/tagHelper.js index 5accca4e..498aa3b2 100644 --- a/forward_engineering/helpers/tagHelper.js +++ b/forward_engineering/helpers/tagHelper.js @@ -9,7 +9,7 @@ module.exports = ({ getName, toString }) => { * @param {{ tags: Tag[], isCaseSensitive: boolean, indent: string }} * @returns {string} */ - const getTagStatement = ({ tags, isCaseSensitive, indent }) => { + const getTagStatement = ({ tags, isCaseSensitive, indent = ' ' }) => { if (isEmpty(tags)) { return ''; } @@ -19,7 +19,7 @@ module.exports = ({ getName, toString }) => { .map(tag => `${getName(isCaseSensitive, tag.tagName)} = ${toString(tag.tagValue)}`) .join(', '); - return `${indent}WITH TAG ${tagStatements}`; + return `${indent}WITH TAG ( ${tagStatements} )`; }; /** diff --git a/properties_pane/entity_level/entityLevelConfig.json b/properties_pane/entity_level/entityLevelConfig.json index b50100bd..bf324d1b 100644 --- a/properties_pane/entity_level/entityLevelConfig.json +++ b/properties_pane/entity_level/entityLevelConfig.json @@ -898,6 +898,29 @@ making sure that you maintain a proper JSON format. "propertyKeyword": "copyGrants", "propertyType": "checkbox" }, + { + "propertyName": "Table Tags", + "propertyKeyword": "tableTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", From ed7610283bae34fa063ee547e7b8a763733ed0e3 Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Wed, 17 Jul 2024 14:27:04 +0300 Subject: [PATCH 4/9] HCK-7186: add ddl generation for view tags --- forward_engineering/configs/templates.js | 2 +- forward_engineering/ddlProvider.js | 8 +++++++ .../view_level/viewLevelConfig.json | 23 +++++++++++++++++++ 3 files changed, 32 insertions(+), 1 deletion(-) diff --git a/forward_engineering/configs/templates.js b/forward_engineering/configs/templates.js index 5c392728..9e63b657 100644 --- a/forward_engineering/configs/templates.js +++ b/forward_engineering/configs/templates.js @@ -25,7 +25,7 @@ module.exports = { createView: 'CREATE${secure}${materialized} VIEW IF NOT EXISTS ${name} (\n' + '\t${column_list}\n' + - ')\n${copy_grants}${comment}AS ${select_statement};\n', + ')\n${copy_grants}${comment}${tag}AS ${select_statement};\n', createUDF: 'CREATE${orReplace} FUNCTION ${name}(${arguments})\n\tRETURNS ${returnType}${notNull}\n\tLANGUAGE ${language}${parameters}${comment}\n\tAS ${body};\n', createProcedure: diff --git a/forward_engineering/ddlProvider.js b/forward_engineering/ddlProvider.js index 8ed08541..efbe9db8 100644 --- a/forward_engineering/ddlProvider.js +++ b/forward_engineering/ddlProvider.js @@ -492,6 +492,12 @@ module.exports = (baseProvider, options, app) => { viewData.selectStatement || `SELECT \n\t${viewColumnsToString(tableColumns, isActivated)}\nFROM ${tables.join(' INNER JOIN ')}`; + const tagStatement = getTagStatement({ + tags: viewData.viewTags, + isCaseSensitive: viewData.isCaseSensitive, + indent: '', + }); + return assignTemplates(templates.createView, { secure: viewData.secure ? ' SECURE' : '', materialized: viewData.materialized ? ' MATERIALIZED' : '', @@ -500,6 +506,7 @@ module.exports = (baseProvider, options, app) => { copy_grants: viewData.copyGrants ? 'COPY GRANTS\n' : '', comment: viewData.comment ? 'COMMENT=$$' + viewData.comment + '$$\n' : '', select_statement: selectStatement, + tag: tagStatement ? tagStatement + '\n' : '', }); }, @@ -836,6 +843,7 @@ module.exports = (baseProvider, options, app) => { secure: firstTab.secure, materialized: firstTab.materialized, fullName, + viewTags: firstTab.viewTags ?? [], }; }, diff --git a/properties_pane/view_level/viewLevelConfig.json b/properties_pane/view_level/viewLevelConfig.json index f3ee3b8c..68b278f1 100644 --- a/properties_pane/view_level/viewLevelConfig.json +++ b/properties_pane/view_level/viewLevelConfig.json @@ -67,6 +67,29 @@ "propertyKeyword": "copyGrants", "shouldValidate": false, "propertyType": "checkbox" + }, + { + "propertyName": "View Tags", + "propertyKeyword": "viewTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] } ] } From 5809e457c5c1ea6be932cf911ffd4818a73249e4 Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Wed, 17 Jul 2024 15:03:47 +0300 Subject: [PATCH 5/9] HCK-7186: add ddl generating for column tags --- forward_engineering/configs/templates.js | 2 +- forward_engineering/ddlProvider.js | 10 +- .../field_level/fieldLevelConfig.json | 347 +++++++++++++++++- 3 files changed, 355 insertions(+), 4 deletions(-) diff --git a/forward_engineering/configs/templates.js b/forward_engineering/configs/templates.js index 9e63b657..bad91e01 100644 --- a/forward_engineering/configs/templates.js +++ b/forward_engineering/configs/templates.js @@ -17,7 +17,7 @@ module.exports = { '\t\t${column_definitions}${out_of_line_constraints}\n' + '\t)${tableOptions};\n', columnDefinition: - '${name} ${type}${collation}${default}${identity}${autoincrement}${not_nul}${inline_constraint}${comment}', + '${name} ${type}${collation}${default}${identity}${autoincrement}${not_nul}${inline_constraint}${comment}${tag}', externalColumnDefinition: '${name} ${type} as ${expression}${comment}', createTableForeignKey: '${constraint}FOREIGN KEY (${columns}) REFERENCES ${primary_table} (${primary_columns})', alterTableForeignKey: diff --git a/forward_engineering/ddlProvider.js b/forward_engineering/ddlProvider.js index efbe9db8..00a4d54f 100644 --- a/forward_engineering/ddlProvider.js +++ b/forward_engineering/ddlProvider.js @@ -397,6 +397,10 @@ module.exports = (baseProvider, options, app) => { not_nul: !columnDefinition.nullable ? ' NOT NULL' : '', inline_constraint: getInlineConstraint(columnDefinition), comment: columnDefinition.comment ? ` COMMENT $$${columnDefinition.comment}$$` : '', + tag: getTagStatement({ + tags: columnDefinition.columnTags, + isCaseSensitive: columnDefinition.isCaseSensitive, + }), }); return { statement: columnStatement, isActivated: columnDefinition.isActivated }; }, @@ -523,7 +527,8 @@ module.exports = (baseProvider, options, app) => { }, hydrateColumn({ columnDefinition, jsonSchema, dbData }) { - return Object.assign({}, columnDefinition, { + return { + ...columnDefinition, name: getName(jsonSchema.isCaseSensitive, columnDefinition.name), isCaseSensitive: jsonSchema.isCaseSensitive, timePrecision: Number(jsonSchema.tPrecision), @@ -562,7 +567,8 @@ module.exports = (baseProvider, options, app) => { uniqueKeyConstraintName: jsonSchema.uniqueKeyConstraintName, primaryKey: jsonSchema.primaryKeyConstraintName ? false : columnDefinition.primaryKey, expression: jsonSchema.expression, - }); + columnTags: jsonSchema.columnTags ?? [], + }; }, hydrateSchema(containerData, { udfs, procedures, sequences, fileFormats, stages, tags } = {}) { diff --git a/properties_pane/field_level/fieldLevelConfig.json b/properties_pane/field_level/fieldLevelConfig.json index 7ada1a4b..9b4cd526 100644 --- a/properties_pane/field_level/fieldLevelConfig.json +++ b/properties_pane/field_level/fieldLevelConfig.json @@ -499,6 +499,29 @@ making sure that you maintain a proper JSON format. } }, "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -904,6 +927,29 @@ making sure that you maintain a proper JSON format. "pattern", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -1291,6 +1337,29 @@ making sure that you maintain a proper JSON format. "pattern", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -1678,6 +1747,29 @@ making sure that you maintain a proper JSON format. "pattern", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -2065,6 +2157,29 @@ making sure that you maintain a proper JSON format. "pattern", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -2357,6 +2472,29 @@ making sure that you maintain a proper JSON format. }, "default", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -2662,6 +2800,29 @@ making sure that you maintain a proper JSON format. "value": true } }, + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -2959,6 +3120,29 @@ making sure that you maintain a proper JSON format. "default", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -3265,6 +3449,29 @@ making sure that you maintain a proper JSON format. "default", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -3579,6 +3786,29 @@ making sure that you maintain a proper JSON format. "default", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -3893,6 +4123,29 @@ making sure that you maintain a proper JSON format. "default", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -4207,6 +4460,29 @@ making sure that you maintain a proper JSON format. "default", "enum", "sample", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -4603,6 +4879,29 @@ making sure that you maintain a proper JSON format. "maxProperties", "dependencies", "additionalProperties", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -4911,6 +5210,29 @@ making sure that you maintain a proper JSON format. "maxProperties", "dependencies", "additionalProperties", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + }, { "propertyName": "Remarks", "propertyKeyword": "comments", @@ -4974,7 +5296,30 @@ making sure that you maintain a proper JSON format. "template": "textarea" }, "minProperties", - "maxProperties" + "maxProperties", + { + "propertyName": "Column Tags", + "propertyKeyword": "columnTags", + "propertyTooltip": "", + "propertyType": "group", + "groupItemLimit": 50, + "structure": [ + { + "propertyName": "Tag name", + "propertyKeyword": "tagName", + "propertyTooltip": "", + "propertyType": "text" + }, + { + "propertyName": "Value", + "propertyKeyword": "tagValue", + "propertyTooltip": "The value of the tag.", + "propertyType": "details", + "template": "textarea", + "markdown": false + } + ] + } ] } } From 3a7ebaac7695c60f7444683d119cdcb485623f6c Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Thu, 18 Jul 2024 16:47:26 +0300 Subject: [PATCH 6/9] HCK-7186: add schema name to tag name --- forward_engineering/configs/templates.js | 2 +- forward_engineering/ddlProvider.js | 22 +++++++++++++++++----- forward_engineering/helpers/tagHelper.js | 19 ++++++++++++++----- 3 files changed, 32 insertions(+), 11 deletions(-) diff --git a/forward_engineering/configs/templates.js b/forward_engineering/configs/templates.js index bad91e01..d8255af3 100644 --- a/forward_engineering/configs/templates.js +++ b/forward_engineering/configs/templates.js @@ -1,7 +1,7 @@ module.exports = { createDatabase: 'CREATE DATABASE IF NOT EXISTS ${name};\nUSE DATABASE ${name};\n', createSchema: - 'CREATE${transient} SCHEMA IF NOT EXISTS ${name}${managed_access}${data_retention}${comment}${tag};\nUSE SCHEMA ${name};\n', + 'CREATE${transient} SCHEMA IF NOT EXISTS ${name}${managed_access}${data_retention}${comment};\nUSE SCHEMA ${name};\n', createTable: 'CREATE${temporary}${transient} TABLE IF NOT EXISTS\n' + '\t${name} (\n' + diff --git a/forward_engineering/ddlProvider.js b/forward_engineering/ddlProvider.js index 00a4d54f..fcdafeed 100644 --- a/forward_engineering/ddlProvider.js +++ b/forward_engineering/ddlProvider.js @@ -64,7 +64,10 @@ module.exports = (baseProvider, options, app) => { tab, }); - const { getTagStatement, getTagAllowedValues } = require('./helpers/tagHelper')({ getName, toString }); + const { getTagStatement, getTagAllowedValues, getTagKeyValues } = require('./helpers/tagHelper')({ + getName, + toString, + }); const getOutOfLineConstraints = ( foreignKeyConstraints, @@ -108,14 +111,12 @@ module.exports = (baseProvider, options, app) => { const currentSchemaName = getName(isCaseSensitive, schemaName); const currentDatabaseName = getName(isCaseSensitive, databaseName); const fullName = getFullName(currentDatabaseName, currentSchemaName); - const tagStatement = getTagStatement({ tags: schemaTags, isCaseSensitive, indent: '\n\t' }); const schemaStatement = assignTemplates(templates.createSchema, { name: fullName, transient: transientStatement, managed_access: managedAccessStatement, data_retention: dataRetentionStatement, comment: commentStatement, - tag: tagStatement, }); const getParameters = payload => { @@ -221,11 +222,21 @@ module.exports = (baseProvider, options, app) => { orReplace: getOrReplaceStatement(tag.orReplace), ifNotExist: getIfNotExistStatement(tag.ifNotExist), allowedValues: getTagAllowedValues(tag.allowedValues), - name: getName(isCaseSensitive, tag.name), + name: getFullName(currentSchemaName, getName(isCaseSensitive, tag.name)), comment: getCommentsStatement(tag.description), }), ); + if (!_.isEmpty(schemaTags)) { + const schemaTagStatement = assignTemplates(templates.alterSchema, { + name: fullName, + operation: 'SET TAG', + options: getTagKeyValues({ tags: schemaTags, isCaseSensitive }), + }); + + tagsStatements.push(schemaTagStatement); + } + const statements = []; if (databaseName) { @@ -233,7 +244,7 @@ module.exports = (baseProvider, options, app) => { assignTemplates(templates.createDatabase, { name: getName(isCaseSensitive, databaseName) }), ); } - statements.push(...tagsStatements); + statements.push(schemaStatement); return [ @@ -243,6 +254,7 @@ module.exports = (baseProvider, options, app) => { ...sequencesStatements, ...fileFormatsStatements, ...stagesStatements, + ...tagsStatements, ].join('\n'); }, diff --git a/forward_engineering/helpers/tagHelper.js b/forward_engineering/helpers/tagHelper.js index 498aa3b2..320934d8 100644 --- a/forward_engineering/helpers/tagHelper.js +++ b/forward_engineering/helpers/tagHelper.js @@ -14,12 +14,9 @@ module.exports = ({ getName, toString }) => { return ''; } - const tagStatements = tags - .filter(tag => tag.tagName) - .map(tag => `${getName(isCaseSensitive, tag.tagName)} = ${toString(tag.tagValue)}`) - .join(', '); + const keyValues = getTagKeyValues({ tags, isCaseSensitive }); - return `${indent}WITH TAG ( ${tagStatements} )`; + return `${indent}WITH TAG ( ${keyValues} )`; }; /** @@ -36,8 +33,20 @@ module.exports = ({ getName, toString }) => { return ` ALLOWED_VALUES ${values}`; }; + /** + * @param {{ tags: Tag[], isCaseSensitive: boolean }} + * @returns {string} + */ + const getTagKeyValues = ({ tags, isCaseSensitive }) => { + return tags + .filter(tag => tag.tagName) + .map(tag => `${getName(isCaseSensitive, tag.tagName)} = ${toString(tag.tagValue)}`) + .join(', '); + }; + return { getTagStatement, getTagAllowedValues, + getTagKeyValues, }; }; From e85bd0437537de17bdab23c85fe03181c1f502fe Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Fri, 19 Jul 2024 11:42:28 +0300 Subject: [PATCH 7/9] HCK-7186: add schema name to tag nameHCK-7186: remove single tooltip --- .../container_level/containerLevelConfig.json | 2 +- .../entity_level/entityLevelConfig.json | 2 +- .../field_level/fieldLevelConfig.json | 30 +++++++++---------- .../view_level/viewLevelConfig.json | 2 +- 4 files changed, 18 insertions(+), 18 deletions(-) diff --git a/properties_pane/container_level/containerLevelConfig.json b/properties_pane/container_level/containerLevelConfig.json index 414e7738..a059f3d8 100644 --- a/properties_pane/container_level/containerLevelConfig.json +++ b/properties_pane/container_level/containerLevelConfig.json @@ -172,7 +172,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false diff --git a/properties_pane/entity_level/entityLevelConfig.json b/properties_pane/entity_level/entityLevelConfig.json index bf324d1b..20908aed 100644 --- a/properties_pane/entity_level/entityLevelConfig.json +++ b/properties_pane/entity_level/entityLevelConfig.json @@ -914,7 +914,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false diff --git a/properties_pane/field_level/fieldLevelConfig.json b/properties_pane/field_level/fieldLevelConfig.json index 9b4cd526..dc852fe1 100644 --- a/properties_pane/field_level/fieldLevelConfig.json +++ b/properties_pane/field_level/fieldLevelConfig.json @@ -515,7 +515,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -943,7 +943,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -1353,7 +1353,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -1763,7 +1763,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -2173,7 +2173,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -2488,7 +2488,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -2816,7 +2816,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -3136,7 +3136,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -3465,7 +3465,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -3802,7 +3802,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -4139,7 +4139,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -4476,7 +4476,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -4895,7 +4895,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -5226,7 +5226,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false @@ -5313,7 +5313,7 @@ making sure that you maintain a proper JSON format. { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false diff --git a/properties_pane/view_level/viewLevelConfig.json b/properties_pane/view_level/viewLevelConfig.json index 68b278f1..d6c506ce 100644 --- a/properties_pane/view_level/viewLevelConfig.json +++ b/properties_pane/view_level/viewLevelConfig.json @@ -84,7 +84,7 @@ { "propertyName": "Value", "propertyKeyword": "tagValue", - "propertyTooltip": "The value of the tag.", + "propertyTooltip": "", "propertyType": "details", "template": "textarea", "markdown": false From 1dfb9387f5b4ca6f206e190f38f9138478188035 Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Fri, 19 Jul 2024 12:31:51 +0300 Subject: [PATCH 8/9] HCK-7186: fix tag name quoting --- forward_engineering/helpers/tagHelper.js | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/forward_engineering/helpers/tagHelper.js b/forward_engineering/helpers/tagHelper.js index 320934d8..c177b301 100644 --- a/forward_engineering/helpers/tagHelper.js +++ b/forward_engineering/helpers/tagHelper.js @@ -40,10 +40,20 @@ module.exports = ({ getName, toString }) => { const getTagKeyValues = ({ tags, isCaseSensitive }) => { return tags .filter(tag => tag.tagName) - .map(tag => `${getName(isCaseSensitive, tag.tagName)} = ${toString(tag.tagValue)}`) + .map(tag => `${getTagName({ tagName: tag.tagName, isCaseSensitive })} = ${toString(tag.tagValue)}`) .join(', '); }; + /** + * @param {{ tagName: string, isCaseSensitive: boolean }} + * @returns {string} + */ + const getTagName = ({ tagName, isCaseSensitive }) => { + const hasSpace = /\s/.test(tagName); + + return hasSpace ? getName(isCaseSensitive, tagName) : tagName; + }; + return { getTagStatement, getTagAllowedValues, From e07064df9d460ca2d97d88f1ba313f90519d697c Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Fri, 19 Jul 2024 14:43:16 +0300 Subject: [PATCH 9/9] HCK-7186: fix remarks --- forward_engineering/ddlProvider.js | 2 +- forward_engineering/helpers/tagHelper.js | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/forward_engineering/ddlProvider.js b/forward_engineering/ddlProvider.js index fcdafeed..62abb141 100644 --- a/forward_engineering/ddlProvider.js +++ b/forward_engineering/ddlProvider.js @@ -221,7 +221,7 @@ module.exports = (baseProvider, options, app) => { assignTemplates(templates.createTag, { orReplace: getOrReplaceStatement(tag.orReplace), ifNotExist: getIfNotExistStatement(tag.ifNotExist), - allowedValues: getTagAllowedValues(tag.allowedValues), + allowedValues: getTagAllowedValues({ allowedValues: tag.allowedValues }), name: getFullName(currentSchemaName, getName(isCaseSensitive, tag.name)), comment: getCommentsStatement(tag.description), }), diff --git a/forward_engineering/helpers/tagHelper.js b/forward_engineering/helpers/tagHelper.js index c177b301..613f666a 100644 --- a/forward_engineering/helpers/tagHelper.js +++ b/forward_engineering/helpers/tagHelper.js @@ -20,10 +20,10 @@ module.exports = ({ getName, toString }) => { }; /** - * @param {string[]} allowedValues + * @param {{ allowedValues: string[] }} * @returns {string} */ - const getTagAllowedValues = allowedValues => { + const getTagAllowedValues = ({ allowedValues }) => { if (isEmpty(allowedValues)) { return ''; }