de.opitzconsulting.orcas.diff.Parameters Maven / Gradle / Ivy
package de.opitzconsulting.orcas.diff;
import java.io.File;
import java.net.URL;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.function.Consumer;
import java.util.function.UnaryOperator;
import org.eclipse.emf.ecore.EObject;
import de.opitzconsulting.orcas.sql.CallableStatementProvider;
public abstract class Parameters {
public void setExtractViewCommnets(boolean pExtractViewCommnents) {
setExtractViewCommnents(pExtractViewCommnents);
}
public void setExtractViewCommnents(boolean pExtractViewCommnents) {
isExtractViewCommnents = pExtractViewCommnents;
}
private boolean isExtractViewCommnents = ParameterDefaults.isExtractViewCommnents;
public Consumer getConnectionInitializer() {
return connectionInitializer;
}
public boolean isExtractViewCommnents() {
return isExtractViewCommnents;
}
public static class JdbcConnectParameters {
String _jdbcDriver;
String _jdbcUrl;
String _jdbcUser;
String _jdbcPassword;
public String getJdbcDriver() {
return _jdbcDriver;
}
public String getJdbcUrl() {
return checkNull(_jdbcUrl);
}
public String getJdbcUser() {
return checkNull(_jdbcUser);
}
public String getJdbcPassword() {
return checkNull(_jdbcPassword);
}
public void setJdbcDriver(String pJdbcDriver) {
_jdbcDriver = pJdbcDriver;
}
public void setJdbcUrl(String pJdbcUrl) {
_jdbcUrl = pJdbcUrl;
}
public void setJdbcUser(String pJdbcUser) {
_jdbcUser = pJdbcUser;
}
public void setJdbcPassword(String pJdbcPassword) {
_jdbcPassword = pJdbcPassword;
}
}
public static enum FailOnErrorMode {
NEVER, ALWAYS, IGNORE_DROP
}
public void setMultiSchemaConnectionManager(MultiSchemaConnectionManager pMultiSchemaConnectionManager) {
_multiSchemaConnectionManager = pMultiSchemaConnectionManager;
if (_multiSchemaConnectionManager instanceof BaseMultiSchemaConnectionManager) {
((BaseMultiSchemaConnectionManager) _multiSchemaConnectionManager).setParameters(this);
}
}
private MultiSchemaConnectionManager _multiSchemaConnectionManager = new MultiSchemaConnectionManagerSimple();
protected JdbcConnectParameters _jdbcConnectParameters = new JdbcConnectParameters();
protected JdbcConnectParameters _srcJdbcConnectParameters;
protected JdbcConnectParameters _orcasJdbcConnectParameters;
protected Boolean _logonly;
protected Boolean _dropmode;
protected Boolean _indexparallelcreate;
protected Boolean _indexmovetablespace;
protected Boolean _tablemovetablespace;
public void setConnectionInitializer(Consumer pConnectionInitializer) {
connectionInitializer = pConnectionInitializer;
}
private Consumer connectionInitializer = p -> {
};
public int getStaticsSpoolMaxLineLength() {
return staticsSpoolMaxLineLength;
}
public void setStaticsSpoolMaxLineLength(int pStaticsSpoolMaxLineLength) {
staticsSpoolMaxLineLength = pStaticsSpoolMaxLineLength;
}
private int staticsSpoolMaxLineLength = ParameterDefaults.staticsSpoolMaxLineLength;
public boolean isLogCompileErrors() {
return logCompileErrors;
}
public void setLogCompileErrors(boolean pLogCompileErrors) {
logCompileErrors = pLogCompileErrors;
}
private boolean logCompileErrors = ParameterDefaults.logCompileErrors;
public boolean isMviewlogmovetablespace() {
return _mviewlogmovetablespace;
}
public void setMviewlogmovetablespace(boolean pMviewlogmovetablespace) {
_mviewlogmovetablespace = pMviewlogmovetablespace;
}
protected boolean _mviewlogmovetablespace = ParameterDefaults.mviewlogmovetablespace;
protected Boolean _createmissingfkindexes;
protected Boolean _isOneTimeScriptMode;
protected Boolean _isOneTimeScriptLogonlyMode;
protected String _modelFile;
protected String _spoolfile;
protected String _excludewheretable;
protected String _excludewheresequence;
public String getExcludewheremview() {
return _excludewheremview;
}
public void setExcludewheremview(String pExcludewheremview) {
_excludewheremview = pExcludewheremview;
}
protected String _excludewheremview = ParameterDefaults.excludewheremview;
private String excludewheregrant = ParameterDefaults.excludewheregrant;
private String excludewheresynonym = ParameterDefaults.excludewheresynonym;
protected String _dateformat;
protected String _orcasDbUser;
protected Boolean _scriptfolderrecursive;
protected String _scriptprefix;
protected String _scriptpostfix;
protected String _loglevel;
protected String _targetplsql;
protected Boolean _sqlplustable;
protected Boolean _orderColumnsByName;
protected Boolean _removeDefaultValuesFromModel;
protected String _viewExtractMode;
protected List _additionalParameters;
protected String _logname;
protected String _spoolfolder;
protected FailOnErrorMode _failOnErrorMode = FailOnErrorMode.ALWAYS;
protected String _extensionParameter;
protected String _initializeChecksumTotal;
protected String _initializeChecksumExtension;
protected boolean _keepDriverClassLoadMessages = true;
protected List _modelFiles;
protected List _relevantModelFiles;
protected List _relevantTables;
protected List _relevantSequences;
public List getRelevantMviews() {
return _relevantMviews;
}
public void setRelevantMviews(List pRelevantMviews) {
_relevantMviews = pRelevantMviews;
}
protected List _relevantMviews;
protected List _schemaFiles = null;
protected URL _scriptUrl;
protected String _scriptUrlFilename;
protected Charset _scriptUrlCharset;
protected Boolean _loadExtractWithReverseExtensions = true;
protected Boolean _multiSchema = false;
protected Boolean _multiSchemaDbaViews = false;
protected String _multiSchemaExcludewhereowner;
protected boolean _additionsOnly = false;
protected boolean _logIgnoredStatements = true;
protected String _xmlLogFile;
protected String _xmlInputFile;
protected boolean _setUnusedInsteadOfDropColumn = false;
protected boolean _createIndexOnline = false;
protected boolean _minimizeStatementCount = false;
protected boolean _cleanupFkValuesOnDropmode = false;
private boolean updateEnabledStatus = ParameterDefaults.updateEnabledStatus;
private String excludewhereview = ParameterDefaults.excludewhereview;
public String getExcludewhereview() {
return excludewhereview;
}
public void setExcludewhereview(String pExcludewhereview) {
excludewhereview = pExcludewhereview;
}
public String getExcludewhereobjecttype() {
return excludewhereobjecttype;
}
public void setExcludewhereobjecttype(String pExcludewhereobjecttype) {
excludewhereobjecttype = pExcludewhereobjecttype;
}
public String getExcludewherepackage() {
return excludewherepackage;
}
public void setExcludewherepackage(String pExcludewherepackage) {
excludewherepackage = pExcludewherepackage;
}
public String getExcludewheretrigger() {
return excludewheretrigger;
}
public void setExcludewheretrigger(String pExcludewheretrigger) {
excludewheretrigger = pExcludewheretrigger;
}
public String getExcludewherefunction() {
return excludewherefunction;
}
public void setExcludewherefunction(String pExcludewherefunction) {
excludewherefunction = pExcludewherefunction;
}
public String getExcludewhereprocedure() {
return excludewhereprocedure;
}
public void setExcludewhereprocedure(String pExcludewhereprocedure) {
excludewhereprocedure = pExcludewhereprocedure;
}
private String excludewhereobjecttype = ParameterDefaults.excludewhereobjecttype;
private String excludewherepackage = ParameterDefaults.excludewherepackage;
private String excludewheretrigger = ParameterDefaults.excludewheretrigger;
private String excludewherefunction = ParameterDefaults.excludewherefunction;
private String excludewhereprocedure = ParameterDefaults.excludewhereprocedure;
public ExecuteSqlErrorHandler getExecuteSqlErrorHandler() {
return executeSqlErrorHandler;
}
public void setExecuteSqlErrorHandler(ExecuteSqlErrorHandler pExecuteSqlErrorHandler) {
executeSqlErrorHandler = pExecuteSqlErrorHandler;
}
private ExecuteSqlErrorHandler executeSqlErrorHandler = ParameterDefaults.executeSqlErrorHandler;
private InfoLogHandler _infoLogHandler;
private String _removePromptPrefix;
protected String _charsetName = StandardCharsets.UTF_8.name();
protected String _charsetNameSqlLog = null;
protected boolean _dbdocPlantuml = false;
public boolean isUpdateEnabledStatus() {
return updateEnabledStatus;
}
public void setUpdateEnabledStatus(boolean pUpdateEnabledStatus) {
updateEnabledStatus = pUpdateEnabledStatus;
}
private final List> extensions = new ArrayList<>();
private final List> reverseExtensions = new ArrayList<>();
public void addExtension( UnaryOperator pExtension ) {
extensions.add(pExtension);
}
public void addReverseExtension( UnaryOperator pExtension ) {
reverseExtensions.add(pExtension);
}
private AdditionalExtensionFactory _additionalExtensionFactory = new AdditionalExtensionFactory() {
@SuppressWarnings("unchecked")
@Override
public List> getAdditionalExtensions(Class pModelClass, boolean pReverseMode) {
return (List>)(List>)(pReverseMode ? reverseExtensions : extensions);
}
};
private ExtensionHandler extensionHandler;
private String extensionhandlerClass = "de.opitzconsulting.orcas.diff.ExtensionHandlerImpl";
public void setExtensionhandlerClass(String pExtensionhandlerClass) {
extensionhandlerClass = pExtensionhandlerClass;
}
public String getExcludewheregrant() {
return excludewheregrant;
}
public void setExcludewheregrant(String pExcludewheregrant) {
excludewheregrant = pExcludewheregrant;
}
public boolean isMinimizeStatementCount() {
return _minimizeStatementCount;
}
public boolean isAdditionsOnly() {
return _additionsOnly;
}
public boolean isOrderColumnsByName() {
return checkNull(_orderColumnsByName);
}
public boolean isRemoveDefaultValuesFromModel() {
return checkNull(_removeDefaultValuesFromModel);
}
public Boolean getSqlplustable() {
return checkNull(_sqlplustable);
}
public String getExcludewheresynonym() {
return excludewheresynonym;
}
public void setExcludewheresynonym(String pExcludewheresynonym) {
excludewheresynonym = pExcludewheresynonym;
}
public JdbcConnectParameters getSrcJdbcConnectParameters() {
return _srcJdbcConnectParameters;
}
public JdbcConnectParameters getOrcasJdbcConnectParameters() {
return checkNull(_orcasJdbcConnectParameters);
}
public String getTargetplsql() {
return checkNull(_targetplsql);
}
public String getInitializeChecksumTotal() {
return _initializeChecksumTotal;
}
public String getInitializeChecksumExtension() {
return _initializeChecksumExtension;
}
public List getAdditionalParameters() {
return checkNull(_additionalParameters);
}
public String getViewExtractMode() {
return checkNull(_viewExtractMode);
}
public boolean isViewExtractModeFull() {
return "full".equals( getViewExtractMode() );
}
public boolean getScriptfolderrecursive() {
return checkNull(_scriptfolderrecursive);
}
public String getScriptprefix() {
return checkNull(_scriptprefix);
}
public String getLogname() {
return checkNull(_logname);
}
public boolean isLognameSet() {
return _logname != null && !getLogname().equals("");
}
public String getSpoolfolder() {
return checkNull(_spoolfolder);
}
public boolean isSpoolfolderSet() {
return _spoolfolder != null && !getSpoolfolder().equals("");
}
public String getScriptpostfix() {
return checkNull(_scriptpostfix);
}
public String getOrcasDbUser() {
return checkNull(_orcasDbUser);
}
private static T checkNull(T pValue) {
if (pValue == null) {
//throw new IllegalArgumentException("Parameter not set");
}
return pValue;
}
public String getExcludewheretable() {
return checkNull(_excludewheretable);
}
public String getExcludewheresequence() {
return checkNull(_excludewheresequence);
}
public String getDateformat() {
return checkNull(_dateformat);
}
public String getModelFile() {
return checkNull(_modelFile);
}
public String getSpoolfile() {
return checkNull(_spoolfile);
}
public JdbcConnectParameters getJdbcConnectParameters() {
return _jdbcConnectParameters;
}
public MultiSchemaConnectionManager getMultiSchemaConnectionManager() {
return _multiSchemaConnectionManager;
}
public boolean isLogonly() {
return checkNull(_logonly);
}
public boolean isDropmode() {
return checkNull(_dropmode);
}
public boolean isCleanupFkValuesOnDropmode() {
return isDropmode() && _cleanupFkValuesOnDropmode;
}
public boolean isIndexparallelcreate() {
return checkNull(_indexparallelcreate);
}
public boolean isIndexmovetablespace() {
return checkNull(_indexmovetablespace);
}
public boolean isTablemovetablespace() {
return checkNull(_tablemovetablespace);
}
public boolean isCreatemissingfkindexes() {
return checkNull(_createmissingfkindexes);
}
public FailOnErrorMode getFailOnErrorMode() {
return checkNull(_failOnErrorMode);
}
public boolean isOneTimeScriptMode() {
return checkNull(_isOneTimeScriptMode);
}
public boolean isOneTimeScriptLogonlyMode() {
return checkNull(_isOneTimeScriptLogonlyMode);
}
public String getExtensionParameter() {
return checkNull(_extensionParameter);
}
public String getloglevel() {
return checkNull(_loglevel);
}
public URL getScriptUrl() {
return _scriptUrl;
}
public Charset getScriptUrlCharset() {
return _scriptUrlCharset;
}
public String getScriptUrlFilename() {
return _scriptUrlFilename;
}
public interface InfoLogHandler {
void logInfo(String pLogMessage);
}
public InfoLogHandler getInfoLogHandler() {
return _infoLogHandler;
}
public void setInfoLogHandler(InfoLogHandler pInfoLogHandler) {
_infoLogHandler = pInfoLogHandler;
}
public boolean isLoadExtractWithReverseExtensions() {
return checkNull(_loadExtractWithReverseExtensions);
}
public String getRemovePromptPrefix() {
return _removePromptPrefix;
}
public void setRemovePromptPrefix(String pRemovePromptPrefix) {
_removePromptPrefix = pRemovePromptPrefix;
}
public boolean isKeepDriverClassLoadMessages() {
return _keepDriverClassLoadMessages;
}
public List getModelFiles() {
return _modelFiles;
}
public ExtensionHandler getExtensionHandler() {
if (extensionHandler == null) {
try {
Class> lExtensionHandlerImplClass = Thread.currentThread().getContextClassLoader().loadClass(extensionhandlerClass);
setExtensionHandler((ExtensionHandler) lExtensionHandlerImplClass.newInstance());
} catch (Exception e) {
throw new RuntimeException(e);
}
}
return extensionHandler;
}
public void setExtensionHandler(ExtensionHandler pExtensionHandler) {
extensionHandler = pExtensionHandler;
extensionHandler.setParameters(this);
}
public abstract boolean isAbortJvmOnExit();
public Boolean getMultiSchema() {
return checkNull(_multiSchema);
}
public String getMultiSchemaExcludewhereowner() {
return _multiSchemaExcludewhereowner;
}
public Boolean getMultiSchemaDbaViews() {
return checkNull(_multiSchemaDbaViews);
}
public AdditionalExtensionFactory getAdditionalOrcasExtensionFactory() {
return _additionalExtensionFactory;
}
public void setAdditionalOrcasExtensionFactory(AdditionalExtensionFactory pAdditionalExtensionFactory) {
_additionalExtensionFactory = pAdditionalExtensionFactory;
}
public interface AdditionalExtensionFactory {
List> getAdditionalExtensions(Class pModelClass, boolean pReverseMode);
}
public boolean isLogIgnoredStatements() {
return _logIgnoredStatements;
}
public String getXmlLogFile() {
return _xmlLogFile;
}
public String getXmlInputFile() {
return _xmlInputFile;
}
public boolean isSetUnusedInsteadOfDropColumn() {
return _setUnusedInsteadOfDropColumn;
}
public boolean isCreateIndexOnline() {
return _createIndexOnline;
}
public Charset getEncoding() {
return Charset.forName(_charsetName);
}
public Charset getEncodingForSqlLog() {
return _charsetNameSqlLog == null ? getEncoding() : Charset.forName(_charsetNameSqlLog);
}
public boolean getDbdocPlantuml() {
return _dbdocPlantuml;
}
public List getSchemaFiles() {
return _schemaFiles;
}
public List getRelevantModelFiles() {
return _relevantModelFiles;
}
public List getRelevantTables() {
return _relevantTables;
}
public List getRelevantSequences() {
return _relevantSequences;
}
public void setRelevantTables(List pRelevantTables) {
_relevantTables = pRelevantTables;
}
public void setRelevantSequences(List pRelevantSequences) {
_relevantSequences = pRelevantSequences;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy