diff --git a/process/Liquibase_lib/process.js b/process/Liquibase_lib/process.js index f7656297bf61248f10f6e4f97f3ae7184ddd907d..a885c6706d403e86ccb668c3a1c5b8c0f4556cf6 100644 --- a/process/Liquibase_lib/process.js +++ b/process/Liquibase_lib/process.js @@ -1,3 +1,4 @@ +import("system.text"); import("system.translate"); import("Util_lib"); import("system.fileIO"); @@ -27,25 +28,31 @@ function LiquiUtils(){} * note that the liquibase tables "DATABASECHANGELOG" and "DATABASECHANGELOGLOCK" will never be exported * (regardless of what you specify here) * @param {Boolean} [pIncludeClearTableDirective=false] if true, a delete element is added at the beginning of the changeset for the table +* @param {Boolean} [pGenerateChangeSetIdFromArguments=false] if true the id of the changeset will be generated by the passed arguments to this function * -* @return void +* @return {Object} returns an object that has currently only one property<br/>- exportedTables:Array of tableNames that have been exported +* * */ -LiquiUtils.exportAllTablesAsLiquibaseFiles = function(pOutFolderPath, pAuthor, pAlias, pExcludedTables, pIncludeClearTableDirective) +LiquiUtils.exportAllTablesAsLiquibaseFiles = function(pOutFolderPath, pAuthor, pAlias, pExcludedTables, pIncludeClearTableDirective, pGenerateChangeSetIdFromArguments) { var excludedTables = ["DATABASECHANGELOG", "DATABASECHANGELOGLOCK"];//liquibase-tables - therefor they shall never be included if (pExcludedTables) excludedTables = excludedTables.concat(pExcludedTables); var alias = pAlias || db.getCurrentAlias(); var tables = db.getTables(alias); + var exportedTables = []; for (var i = 0, l = tables.length; i < l; i++) { if (ArrayUtils.hasElement(excludedTables, tables[i], true)) continue; var cond = null; - LiquiUtils.exportTableAsLiquibaseFiles(pOutFolderPath, tables[i], null, cond, pAuthor, pIncludeClearTableDirective, alias); + var res = LiquiUtils.exportTableAsLiquibaseFiles(pOutFolderPath, tables[i], null, cond, pAuthor, pIncludeClearTableDirective, alias, pGenerateChangeSetIdFromArguments); + if (res.exported) + exportedTables.push(tables[i]); } + return {exportedTables: exportedTables} }; /** @@ -59,19 +66,20 @@ LiquiUtils.exportAllTablesAsLiquibaseFiles = function(pOutFolderPath, pAuthor, p * @param {String} [pAuthor="autogenerated"] author that will be written into the liquibase-changeset * @param {Boolean} [pIncludeClearTableDirective=false] if true, a delete element is added at the beginning of the changeset for the table * @param {String} [pAlias=current db-alias] alias where the data will be loaded from +* @param {Boolean} [pGenerateChangeSetIdFromArguments=false] if true the id of the changeset will be generated by the passed arguments to this function * -* @return {null} returns currently always null +* @return {Object} returns an object that has currently only one property<br/>- exported:boolean if the table has been exported or not */ -LiquiUtils.exportTableAsLiquibaseFiles = function(pPath, pTableName, pColumns, pCondition, pAuthor, pIncludeClearTableDirective, pAlias) +LiquiUtils.exportTableAsLiquibaseFiles = function(pPath, pTableName, pColumns, pCondition, pAuthor, pIncludeClearTableDirective, pAlias, pGenerateChangeSetIdFromArguments) { - var resXml = LiquiUtils._getDataXml(pAuthor, pPath, pTableName, pColumns, pCondition, pIncludeClearTableDirective, pAlias); + var resXml = LiquiUtils._getDataXml(pAuthor, pPath, pTableName, pColumns, pCondition, pIncludeClearTableDirective, pAlias, pGenerateChangeSetIdFromArguments); if (resXml == "") - return null; + return {exported: false}; fileIO.mkdir(pPath, true); var fullFileName = pPath += "/" + pTableName + ".xml"; fileIO.storeData(fullFileName, resXml, util.DATA_TEXT, false, "UTF8"); - return null; + return {exported: true}; }; /** @@ -88,15 +96,16 @@ LiquiUtils.exportTableAsLiquibaseFiles = function(pPath, pTableName, pColumns, p * @param {String} [pCondition=none] db-condition to limit the data that will be exported; if nothing given the whole content will be exported * @param {Boolean} [pIncludeClearTableDirective=false] if true, a delete element is added at the beginning of the changeset for the table * @param {String} [pAlias=current db-alias] alias where the data will be loaded from +* @param {Boolean} [pGenerateChangeSetIdFromArguments=false] if true the id of the changeset will be generated by the passed arguments to this function * * @return {String} the liquibase-changest in xml-form */ -LiquiUtils._getDataXml = function(pAuthor, pLobPath, pTableName, pColumns, pCondition, pIncludeClearTableDirective, pAlias) +LiquiUtils._getDataXml = function(pAuthor, pLobPath, pTableName, pColumns, pCondition, pIncludeClearTableDirective, pAlias, pGenerateChangeSetIdFromArguments) { var author = pAuthor || "autogenerated"; var alias = pAlias || db.getCurrentAlias(); //cannot be added within jdito code to the XML-object, so instead add it as string - var XML_HEADER_LINE= '<?xml version="1.1" encoding="UTF-8" standalone="no"?>'; + var XML_HEADER_LINE = LiquiXmlUtils.xmlHeaderLineStr(); var columns = pColumns || db.getColumns(pTableName, alias); var dbData = db.table("select " + columns.join(", ") + " from " + pTableName + " " + (pCondition ? "where " + pCondition : ""), alias); @@ -128,7 +137,16 @@ LiquiUtils._getDataXml = function(pAuthor, pLobPath, pTableName, pColumns, pCond }); var columnLen = columns.length; - var changeLogXml = LiquiXmlUtils.databaseChangeLog(author); + var changesetId; + if (pGenerateChangeSetIdFromArguments) + { + changesetId = Array.prototype.slice.call(arguments);//todo: use Array.from instead when supported (>= rhino 1.7.11) + changesetId = changesetId.reduce(function (accumulator, currentValue){ + return (currentValue !== null && currentValue !== undefined ? accumulator + JSON.stringify(currentValue) : accumulator); + }, ""); + changesetId = text.hash(changesetId, text.HASH_MD5); + }//or otherwise is the changesetId automatically generated within the databaseChangeLogWithChangeSet function + var changeLogXml = LiquiXmlUtils.databaseChangeLogWithChangeSet(author, changesetId); if (pIncludeClearTableDirective) changeLogXml.changeSet.appendChild(<delete tableName={pTableName}/>); dbData.forEach(function(row) @@ -158,16 +176,23 @@ LiquiUtils._getDataXml = function(pAuthor, pLobPath, pTableName, pColumns, pCond */ function LiquiXmlUtils(){} - //TODO: comments -LiquiXmlUtils.databaseChangeLog = function (pAuthor, pChangeSetId) +LiquiXmlUtils.xmlHeaderLineStr = function() +{ + return '<?xml version="1.1" encoding="UTF-8" standalone="no"?>'; +}; + +LiquiXmlUtils.databaseChangeLog = function () +{ + return <databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog" xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog-ext http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-ext.xsd http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.6.xsd"/>; +}; + +LiquiXmlUtils.databaseChangeLogWithChangeSet = function (pAuthor, pChangeSetId) { if (pChangeSetId == undefined) pChangeSetId = util.getNewUUID(); - var dbcl = <databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog" xmlns:ext="http://www.liquibase.org/xml/ns/dbchangelog-ext" - xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog-ext http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-ext.xsd http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.6.xsd"/> - ; - + var dbcl = LiquiXmlUtils.databaseChangeLog(); dbcl.changeSet = <changeSet author={pAuthor} id={pChangeSetId} />; return dbcl; }; @@ -274,7 +299,7 @@ LiquiXTable.prototype.addClobCol = function (pColName, pValue) throw new Error(translate.withArguments("[%0]it was necessary to create a text-file from a clob-field but no lob-file-path was specified." + "The lob-file-path is required when adding long clob-values. value length was %1.", ["LiquiXTable addClobCol", pValue.length])); var relativeFolderPath = this._name + "/" + pColName + "/clobFiles/"; - var fileName = util.getNewUUID() + ".txt"; + var fileName = text.hash(pValue, text.HASH_MD5) + ".txt"; fileIO.mkdir(lobBasePath + relativeFolderPath, true); fileIO.storeData(lobBasePath + relativeFolderPath + fileName, pValue, util.DATA_TEXT, false, "UTF8"); return this.appendIfNotNull(LiquiXmlUtils.colValue(pColName, relativeFolderPath + fileName, "valueClobFile")); @@ -290,7 +315,7 @@ LiquiXTable.prototype.addBlobCol = function (pColName, pValue) throw new Error(translate.withArguments("[%0]it was necessary to create a file from a blob-field but no lob-file-path was specified." + "The lob-file-path is required when adding blob-values.", ["LiquiXTable addClobCol"])); var relativeFolderPath = this._name + "/" + pColName + "/blobFiles/"; - var fileName = util.getNewUUID(); + var fileName = text.hash(pValue, text.HASH_MD5); fileIO.mkdir(lobBasePath + relativeFolderPath, true); fileIO.storeData(lobBasePath + relativeFolderPath + fileName, pValue, util.DATA_BINARY, false); return this.appendIfNotNull(LiquiXmlUtils.colValue(pColName, relativeFolderPath + fileName, "valueBlobFile")); diff --git a/process/_test_clientProcess/process.js b/process/_test_clientProcess/process.js index 273b7362004c369f828a237f97eafb777ee393d7..45a99f31db517376f49a73ed8a132b8d55c7ac18 100644 --- a/process/_test_clientProcess/process.js +++ b/process/_test_clientProcess/process.js @@ -1,21 +1 @@ -import("Sql_lib"); -import("system.datetime"); -import("system.util"); -import("system.logging"); -import("Liquibase_lib"); -import("system.db"); -import("system.fileIO"); - -var alias = SqlUtils.getSystemAlias(); -//var alias = "betterDataSys"; -//var alias = "betterData"; -//var alias = db.getCurrentAlias(); -var outFolderPath = "C:\\temp\\generatedData\\" + alias + "\\"; - -var excludedTables = ["AB_COUNTRYINFO", "AB_LANGUAGE"]; -//LiquiUtils.exportAllTablesAsLiquibaseFiles(outFolderPath, null, alias, excludedTables, true); - -alias = SqlUtils.getSystemAlias(); -outFolderPath = "C:\\temp\\generatedData\\" + alias + "\\"; -LiquiUtils.exportTableAsLiquibaseFiles(outFolderPath, "ASYS_USERS", null, "PROPKEY in ('mailserverAlias', 'userserverEnabled') ", null, false, alias); -logging.log("finish"); \ No newline at end of file +throw new Error("proccess not defined") \ No newline at end of file diff --git a/process/exportLiquibaseContent_serverProcess/exportLiquibaseContent_serverProcess.aod b/process/exportLiquibaseContent_serverProcess/exportLiquibaseContent_serverProcess.aod new file mode 100644 index 0000000000000000000000000000000000000000..3da2bf3b5021983b7932b654c170c10ea0738d70 --- /dev/null +++ b/process/exportLiquibaseContent_serverProcess/exportLiquibaseContent_serverProcess.aod @@ -0,0 +1,10 @@ +<?xml version="1.0" encoding="UTF-8"?> +<process xmlns="http://www.adito.de/2018/ao/Model" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" VERSION="1.2.1" xsi:schemaLocation="http://www.adito.de/2018/ao/Model adito://models/xsd/process/1.2.1"> + <name>exportLiquibaseContent_serverProcess</name> + <majorModelMode>DISTRIBUTED</majorModelMode> + <process>%aditoprj%/process/exportLiquibaseContent_serverProcess/process.js</process> + <alias>Data_alias</alias> + <variants> + <element>EXECUTABLE</element> + </variants> +</process> diff --git a/process/exportLiquibaseContent_serverProcess/process.js b/process/exportLiquibaseContent_serverProcess/process.js new file mode 100644 index 0000000000000000000000000000000000000000..2311a5e16b0cda47c3010f8032540b5c3e4043bd --- /dev/null +++ b/process/exportLiquibaseContent_serverProcess/process.js @@ -0,0 +1,36 @@ +import("system.vars"); +import("Sql_lib"); +import("system.datetime"); +import("system.util"); +import("system.logging"); +import("Liquibase_lib"); +import("system.db"); +import("system.fileIO"); + +var alias = "diffAlias"; +var outFolderBase = vars.get("$sys.servertemp") + "/" + alias + "/"; + +var outFolderPath = outFolderBase + "generatedData/"; + +var excludedTables = ["AB_COUNTRYINFO", "AB_LANGUAGE"]; +excludedTables.push("AB_KEYWORD_ATTRIBUTE", "AB_KEYWORD_ATTRIBUTERELATION", "AB_KEYWORD_ENTRY");//TODO: only export parts +var exportRes = LiquiUtils.exportAllTablesAsLiquibaseFiles(outFolderPath, null, alias, excludedTables, true); +var exportedTables = exportRes.exportedTables; +var changeLogData = LiquiXmlUtils.databaseChangeLog("autogenerated"); +exportedTables.forEach(function (tableName){ + var fileValue = "generatedData/" + tableName + ".xml"; + changeLogData.appendChild(<include relativeToChangelogFile="true" file={ + fileValue + }/>); +}); +changeLogData = LiquiXmlUtils.xmlHeaderLineStr() + "\n" + changeLogData.toString(); +fileIO.storeData(outFolderBase + "changelog.xml", changeLogData, util.DATA_TEXT, false, "UTF8"); +logging.log("liquibase data (" + exportedTables.length + " tables) exported into folder:" + outFolderPath); + +//remember to change the alias db to the data_system when running binaries exporter: +//LiquiUtils.exportTableAsLiquibaseFiles(outFolderPath, "ASYS_BINARIES", null, null, null, false, alias); + +//alias = SqlUtils.getSystemAlias(); +//outFolderPath = "C:\\temp\\generatedData\\" + alias + "\\"; +//LiquiUtils.exportTableAsLiquibaseFiles(outFolderPath, "ASYS_USERS", null, "PROPKEY in ('mailserverAlias', 'userserverEnabled') ", null, false, alias); +//logging.log("finish"); \ No newline at end of file