use of org.talend.designer.core.ui.editor.cmd.ChangeMetadataCommand in project tdi-studio-se by Talend.
the class AbstractSchemaController method createButtonCommand.
@Override
protected Command createButtonCommand(Button button) {
// see 0003766: Problems with the read only mode of the properties on repository mode.
if (checkForRepositoryShema(button)) {
return null;
}
Button inputButton = button;
IElementParameter switchParam = elem.getElementParameter(EParameterName.REPOSITORY_ALLOW_AUTO_SWITCH.getName());
if (inputButton.getData(NAME).equals(SCHEMA)) {
// this map wil hold the all input connection for the tUnite component
Map<INode, Map<IMetadataTable, Boolean>> inputInfos = new HashMap<INode, Map<IMetadataTable, Boolean>>();
INode node;
if (elem instanceof Node) {
node = (INode) elem;
} else {
// else instanceof Connection
node = ((IConnection) elem).getSource();
}
IMetadataTable inputMetadata = null, inputMetaCopy = null;
Connection inputConec = null;
String propertyName = (String) inputButton.getData(PARAMETER_NAME);
IElementParameter param = node.getElementParameter(propertyName);
IElementParameter connectionParam = param.getChildParameters().get(EParameterName.CONNECTION.getName());
String connectionName = null;
if (connectionParam != null) {
connectionName = (String) connectionParam.getValue();
}
Object obj = button.getData(FORCE_READ_ONLY);
boolean forceReadOnly = false;
if (obj != null) {
forceReadOnly = (Boolean) obj;
}
boolean inputReadOnly = false, outputReadOnly = false, inputReadOnlyNode = false, inputReadOnlyParam = false;
for (Connection connec : (List<Connection>) node.getIncomingConnections()) {
if (connec.isActivate() && (connec.getLineStyle().equals(EConnectionType.FLOW_MAIN) || connec.getLineStyle().equals(EConnectionType.TABLE) || connec.getLineStyle().equals(EConnectionType.FLOW_MERGE) || connec.getLineStyle() == EConnectionType.FLOW_REF)) {
if (connectionName != null && !connec.getName().equals(connectionName)) {
continue;
}
inputMetadata = connec.getMetadataTable();
inputMetaCopy = inputMetadata.clone();
inputConec = connec;
if (connec.getSource().isReadOnly()) {
inputReadOnlyNode = true;
} else {
for (IElementParameter curParam : connec.getSource().getElementParameters()) {
if (curParam.getFieldType() == EParameterFieldType.SCHEMA_TYPE || curParam.getFieldType() == EParameterFieldType.SCHEMA_REFERENCE) {
if (curParam.isReadOnly()) {
inputReadOnlyParam = true;
}
}
}
}
// check if the inputMetadata is readonly
if (inputMetadata != null) {
for (IMetadataColumn column : inputMetadata.getListColumns(true)) {
IMetadataColumn columnCopied = inputMetaCopy.getColumn(column.getLabel());
columnCopied.setCustom(column.isCustom());
columnCopied.setReadOnly(column.isReadOnly());
}
inputMetaCopy.setReadOnly(inputMetadata.isReadOnly());
inputReadOnly = prepareReadOnlyTable(inputMetaCopy, inputReadOnlyParam, inputReadOnlyNode);
}
// store the value for Dialog
Map<IMetadataTable, Boolean> oneInput = new HashMap<IMetadataTable, Boolean>();
oneInput.put(inputMetaCopy, inputReadOnly);
inputInfos.put(connec.getSource(), oneInput);
}
}
if (connectionParam != null && inputMetadata == null) {
//$NON-NLS-1$
MessageDialog.openError(//$NON-NLS-1$
button.getShell(), //$NON-NLS-1$
Messages.getString("AbstractSchemaController.inputNotSet"), //$NON-NLS-1$
Messages.getString("AbstractSchemaController.connectionNotAvaliable"));
return null;
}
IMetadataTable originaleMetadataTable = getMetadataTableFromXml(node);
// check if the outputMetadata is readonly
IMetadataTable originaleOutputTable = node.getMetadataFromConnector(param.getContext());
// when several schema_type button ,need get the right one which is opening
//$NON-NLS-1$
IElementParameter schemaParam = param.getChildParameters().get("SCHEMA_TYPE");
// need setRepository here
if (!param.getContext().equals(schemaParam.getContext())) {
//$NON-NLS-1$
schemaParam = param.getChildParameters().get("SCHEMA_TYPE");
}
if (schemaParam != null && EmfComponent.REPOSITORY.equals(schemaParam.getValue())) {
if (originaleOutputTable != null && originaleOutputTable instanceof MetadataTable) {
((MetadataTable) originaleOutputTable).setRepository(true);
}
} else if (schemaParam != null && EmfComponent.BUILTIN.equals(schemaParam.getValue())) {
if (originaleOutputTable != null && originaleOutputTable instanceof MetadataTable) {
((MetadataTable) originaleOutputTable).setRepository(false);
}
}
if ("tUniservBTGeneric".equals(node.getComponent().getName())) {
//$NON-NLS-1$
//$NON-NLS-1$
originaleOutputTable = node.getMetadataTable("OUTPUT_SCHEMA");
}
IMetadataTable outputMetaCopy = originaleOutputTable.clone(true);
for (IMetadataColumn column : originaleOutputTable.getListColumns(true)) {
IMetadataColumn columnCopied = outputMetaCopy.getColumn(column.getLabel());
columnCopied.setCustom(column.isCustom());
columnCopied.setReadOnly(column.isReadOnly());
if (//$NON-NLS-1$ //$NON-NLS-2$
("tLogCatcher".equals(node.getComponent().getName()) || "tStatCatcher".equals(node.getComponent().getName())) && !outputMetaCopy.sameMetadataAs(originaleMetadataTable, IMetadataColumn.OPTIONS_NONE)) {
columnCopied.setReadOnly(false);
}
}
outputMetaCopy.setReadOnly(originaleOutputTable.isReadOnly() || param.isReadOnly(node.getElementParametersWithChildrens()));
if (//$NON-NLS-1$ //$NON-NLS-2$
("tLogCatcher".equals(node.getComponent().getName()) || "tStatCatcher".equals(node.getComponent().getName())) && !outputMetaCopy.sameMetadataAs(originaleMetadataTable, IMetadataColumn.OPTIONS_NONE)) {
outputMetaCopy.setReadOnly(false);
}
//$NON-NLS-1$
IElementParameter schemaTypeParam = param.getChildParameters().get("SCHEMA_TYPE");
List<IElementParameterDefaultValue> defaultValues = schemaTypeParam.getDefaultValues();
for (IElementParameterDefaultValue elementParameterDefaultValue : defaultValues) {
if (elementParameterDefaultValue.getDefaultValue() instanceof MetadataTable) {
MetadataTable table = (MetadataTable) elementParameterDefaultValue.getDefaultValue();
outputMetaCopy.setReadOnlyColumnPosition(table.getReadOnlyColumnPosition());
break;
}
}
outputMetaCopy.sortCustomColumns();
if (!forceReadOnly) {
outputReadOnly = prepareReadOnlyTable(outputMetaCopy, param.isReadOnly(), node.isReadOnly());
} else {
outputReadOnly = true;
}
// create the MetadataDialog
MetadataDialog metaDialog = null;
if (inputMetadata != null) {
if (inputInfos != null && inputInfos.size() > 1 && connectionName == null) {
MetadataDialogForMerge metaDialogForMerge = new MetadataDialogForMerge(composite.getShell(), inputInfos, outputMetaCopy, node, getCommandStack());
//$NON-NLS-1$
metaDialogForMerge.setText(Messages.getString("AbstractSchemaController.schemaOf") + node.getLabel());
metaDialogForMerge.setInputReadOnly(inputReadOnly);
metaDialogForMerge.setOutputReadOnly(outputReadOnly);
if (metaDialogForMerge.open() == MetadataDialogForMerge.OK) {
// inputMetaCopy = metaDialog.getInputMetaData();
outputMetaCopy = metaDialogForMerge.getOutputMetaData();
// check if the metadata is modified
boolean modified = false;
if (!outputMetaCopy.sameMetadataAs(originaleOutputTable, IMetadataColumn.OPTIONS_NONE)) {
modified = true;
} else {
if (inputMetadata != null) {
// Notice: the Map inputInfos maybe is modified by the dialog.
Set<INode> inputNodes = inputInfos.keySet();
for (INode inputNode : inputNodes) {
Map<IMetadataTable, Boolean> oneInput = inputInfos.get(inputNode);
inputMetaCopy = (IMetadataTable) oneInput.keySet().toArray()[0];
if (!inputMetaCopy.sameMetadataAs(inputNode.getMetadataList().get(0), IMetadataColumn.OPTIONS_NONE)) {
modified = true;
}
}
}
}
// create the changeMetadataCommand
if (modified) {
if (switchParam != null) {
switchParam.setValue(Boolean.FALSE);
}
Command changeMetadataCommand = null;
// only output, no input
if (inputInfos.isEmpty()) {
changeMetadataCommand = new ChangeMetadataCommand(node, param, null, null, null, originaleOutputTable, outputMetaCopy);
} else {
Set<INode> inputNodes = inputInfos.keySet();
int count = 0;
for (INode inputNode : inputNodes) {
Map<IMetadataTable, Boolean> oneInput = inputInfos.get(inputNode);
inputMetaCopy = (IMetadataTable) oneInput.keySet().toArray()[0];
if (count == 0) {
changeMetadataCommand = new ChangeMetadataCommand(node, param, inputNode, inputNode.getMetadataList().get(0), inputMetaCopy, originaleOutputTable, outputMetaCopy);
} else {
changeMetadataCommand = changeMetadataCommand.chain(new ChangeMetadataCommand(node, param, inputNode, inputNode.getMetadataList().get(0), inputMetaCopy, originaleOutputTable, outputMetaCopy));
}
count++;
}
}
return changeMetadataCommand;
}
}
} else {
INode inputNode = (inputConec.getSource());
if (inputMetaCopy.getAttachedConnector() == null) {
INodeConnector mainConnector;
if (inputNode.isELTComponent()) {
mainConnector = inputNode.getConnectorFromType(EConnectionType.TABLE);
} else {
mainConnector = inputNode.getConnectorFromType(EConnectionType.FLOW_MAIN);
}
inputMetaCopy.setAttachedConnector(mainConnector.getName());
}
metaDialog = new MetadataDialog(composite.getShell(), inputMetaCopy, inputNode, outputMetaCopy, node, getCommandStack());
}
} else {
metaDialog = new MetadataDialog(composite.getShell(), outputMetaCopy, node, getCommandStack());
}
if (metaDialog != null) {
//$NON-NLS-1$
metaDialog.setText(Messages.getString("AbstractSchemaController.schema.title", node.getLabel()));
metaDialog.setInputReadOnly(inputReadOnly);
metaDialog.setOutputReadOnly(outputReadOnly);
setMetadataTableOriginalNameList(inputMetadata, inputMetaCopy);
setMetadataTableOriginalNameList(originaleOutputTable, outputMetaCopy);
if (metaDialog.open() == MetadataDialog.OK) {
inputMetaCopy = metaDialog.getInputMetaData();
outputMetaCopy = metaDialog.getOutputMetaData();
boolean modified = false;
if (!outputMetaCopy.sameMetadataAs(originaleOutputTable, IMetadataColumn.OPTIONS_NONE)) {
modified = true;
} else {
if (inputMetadata != null) {
if (!inputMetaCopy.sameMetadataAs(inputMetadata, IMetadataColumn.OPTIONS_NONE)) {
modified = true;
}
}
}
if (modified) {
if (switchParam != null) {
switchParam.setValue(Boolean.FALSE);
}
INode inputNode = null;
if (inputConec != null) {
inputNode = inputConec.getSource();
}
ChangeMetadataCommand changeMetadataCommand = new ChangeMetadataCommand(node, param, inputNode, inputMetadata, inputMetaCopy, originaleOutputTable, outputMetaCopy);
return changeMetadataCommand;
}
}
}
} else if (inputButton.getData(NAME).equals(RETRIEVE_SCHEMA)) {
Node node = (Node) elem;
// String propertyName = (String) inputButton.getData(PARAMETER_NAME);
final Command cmd = RetrieveSchemaHelper.retrieveSchemasCommand(node);
if (switchParam != null) {
switchParam.setValue(Boolean.FALSE);
}
return cmd;
} else if (inputButton.getData(NAME).equals(RESET_COLUMNS)) {
Node node = (Node) elem;
String propertyName = (String) inputButton.getData(PARAMETER_NAME);
IElementParameter param = node.getElementParameter(propertyName);
final Command cmd = SynchronizeSchemaHelper.createCommand(node, param);
if (switchParam != null) {
switchParam.setValue(Boolean.FALSE);
}
return cmd;
} else if (button.getData(NAME).equals(REPOSITORY_CHOICE)) {
String paramName = (String) button.getData(PARAMETER_NAME);
IElementParameter schemaParam = elem.getElementParameter(paramName);
ERepositoryObjectType type = ERepositoryObjectType.METADATA_CON_TABLE;
String filter = schemaParam.getFilter();
if (elem instanceof Node) {
Node sapNode = (Node) elem;
if (sapNode.getComponent().getName().startsWith("tESB")) {
//$NON-NLS-1$
filter = ERepositoryObjectType.SERVICESOPERATION.getType();
}
}
RepositoryReviewDialog dialog = new RepositoryReviewDialog(button.getShell(), type, filter);
if (dialog.open() == RepositoryReviewDialog.OK) {
RepositoryNode node = dialog.getResult();
while (node.getObject().getProperty().getItem() == null || (!(node.getObject().getProperty().getItem() instanceof ConnectionItem))) {
node = node.getParent();
}
IRepositoryViewObject object = dialog.getResult().getObject();
Property property = object.getProperty();
String id = property.getId();
// The name is Table Name.
String name = object.getLabel();
org.talend.core.model.metadata.builder.connection.MetadataTable table = null;
if (property.getItem() instanceof SAPConnectionItem && object instanceof MetadataTableRepositoryObject) {
MetadataTableRepositoryObject metadataObject = (MetadataTableRepositoryObject) object;
table = (org.talend.core.model.metadata.builder.connection.MetadataTable) metadataObject.getModelElement();
if (table.eContainer() instanceof SAPFunctionUnit) {
SAPFunctionUnit function = (SAPFunctionUnit) table.eContainer();
String tableType = table.getTableType() == null ? MetadataSchemaType.OUTPUT.name() : table.getTableType();
//$NON-NLS-1$ //$NON-NLS-2$
name = function.getLabel() + "/" + tableType + "/" + name;
}
}
if (name != null) {
if (elem instanceof Node) {
Node nodeElement = (Node) elem;
//$NON-NLS-1$
String value = id + " - " + name;
IMetadataTable repositoryMetadata = MetadataToolHelper.getMetadataFromRepository(value);
if (nodeElement.getComponent().getName().equals("tSQLTemplateMerge")) {
//$NON-NLS-1$
if (paramName.equals("SCHEMA")) {
//$NON-NLS-1$
//$NON-NLS-1$
paramName = "SOURCE_TABLE";
Command dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
executeCommand(dbSelectorCommand);
Text labelText = (Text) hashCurControls.get(paramName);
labelText.setText(TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
//$NON-NLS-1$
paramName = "SCHEMA:REPOSITORY_SCHEMA_TYPE";
dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(name));
executeCommand(dbSelectorCommand);
labelText = (Text) hashCurControls.get(paramName);
labelText.setText(TalendTextUtils.addQuotes(name));
//$NON-NLS-1$
paramName = "SCHEMA";
} else if (paramName.equals("SCHEMA_TARGET")) {
//$NON-NLS-1$
//$NON-NLS-1$
paramName = "TARGET_TABLE";
Command dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
executeCommand(dbSelectorCommand);
Text labelText = (Text) hashCurControls.get(paramName);
labelText.setText(TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
//$NON-NLS-1$
paramName = "SCHEMA_TARGET:REPOSITORY_SCHEMA_TYPE";
dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(name));
executeCommand(dbSelectorCommand);
labelText = (Text) hashCurControls.get(paramName);
labelText.setText(TalendTextUtils.addQuotes(name));
//$NON-NLS-1$
paramName = "SCHEMA_TARGET";
}
} else if (nodeElement.getComponent().getName().startsWith("tSQLTemplate")) {
//$NON-NLS-1$
if (paramName.equals("SCHEMA")) {
//$NON-NLS-1$
//$NON-NLS-1$
paramName = "TABLE_NAME";
Command dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
executeCommand(dbSelectorCommand);
Text labelText = (Text) hashCurControls.get(paramName);
labelText.setText(TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
//$NON-NLS-1$
paramName = "SCHEMA:REPOSITORY_SCHEMA_TYPE";
dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(name));
executeCommand(dbSelectorCommand);
labelText = (Text) hashCurControls.get(paramName);
labelText.setText(TalendTextUtils.addQuotes(name));
//$NON-NLS-1$
paramName = "SCHEMA";
} else if (paramName.equals("SCHEMA_TARGET")) {
//$NON-NLS-1$
//$NON-NLS-1$
paramName = "TABLE_NAME_TARGET";
Command dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
executeCommand(dbSelectorCommand);
Text labelText = (Text) hashCurControls.get(paramName);
labelText.setText(TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
//$NON-NLS-1$
paramName = "SCHEMA_TARGET:REPOSITORY_SCHEMA_TYPE";
dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(name));
executeCommand(dbSelectorCommand);
labelText = (Text) hashCurControls.get(paramName);
labelText.setText(TalendTextUtils.addQuotes(name));
//$NON-NLS-1$
paramName = "SCHEMA_TARGET";
}
} else if (nodeElement.getComponent().getName().startsWith("tSalesforce")) {
//$NON-NLS-1$
//$NON-NLS-1$
paramName = paramName + ":" + EParameterName.REPOSITORY_SCHEMA_TYPE.getName();
Command selectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(value));
executeCommand(selectorCommand);
} else {
Command dbSelectorCommand = new PropertyChangeCommand(elem, paramName, TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
executeCommand(dbSelectorCommand);
Text labelText = (Text) hashCurControls.get(paramName);
if (labelText != null) {
labelText.setText(TalendTextUtils.addQuotes(repositoryMetadata.getTableName()));
}
}
}
}
//$NON-NLS-1$
String value = id + " - " + name;
//$NON-NLS-1$
String fullParamName = paramName + ":" + getRepositoryChoiceParamName();
org.talend.core.model.metadata.builder.connection.Connection connection = null;
if (elem instanceof Node) {
IMetadataTable repositoryMetadata = null;
if (table != null && table instanceof SAPBWTable) {
repositoryMetadata = ConvertionHelper.convert(table);
} else {
repositoryMetadata = MetadataToolHelper.getMetadataFromRepository(value);
connection = MetadataToolHelper.getConnectionFromRepository(value);
}
// For SAP see bug 5423
String functionId = node.getParent().getId();
if (//$NON-NLS-1$//$NON-NLS-2$
((Node) elem).getUniqueName().startsWith("tSAP") && !((Node) elem).getUniqueName().startsWith("tSAPHana") && functionId != "-1") {
//$NON-NLS-1$
Node sapNode = (Node) elem;
repositoryMetadata = getMetadataFromRepository(id, functionId, name);
String functionName = node.getParent().getObject().getLabel();
for (IElementParameter param : sapNode.getElementParameters()) {
SAPParametersUtils.retrieveSAPParams(elem, connection, param, functionName);
}
}
// For validation rule.
boolean isValRulesLost = false;
IRepositoryViewObject currentValRuleObj = ValidationRulesUtil.getCurrentValidationRuleObjs(elem);
if (currentValRuleObj != null) {
List<IRepositoryViewObject> valRuleObjs = ValidationRulesUtil.getRelatedValidationRuleObjs(value);
if (!ValidationRulesUtil.isCurrentValRuleObjInList(valRuleObjs, currentValRuleObj)) {
if (!MessageDialog.openConfirm(button.getShell(), //$NON-NLS-1$
Messages.getString("AbstractSchemaController.validationrule.title.confirm"), Messages.getString("AbstractSchemaController.validationrule.selectMetadataMsg"))) {
//$NON-NLS-1$
return null;
} else {
isValRulesLost = true;
}
}
}
if (repositoryMetadata == null) {
repositoryMetadata = new MetadataTable();
}
if (switchParam != null) {
switchParam.setValue(Boolean.FALSE);
}
CompoundCommand cc = new CompoundCommand();
RepositoryChangeMetadataCommand changeMetadataCommand = new RepositoryChangeMetadataCommand((Node) elem, fullParamName, value, repositoryMetadata, null, null, table);
changeMetadataCommand.setConnection(connection);
cc.add(changeMetadataCommand);
if (isValRulesLost) {
ValidationRulesUtil.appendRemoveValidationRuleCommands(cc, elem);
}
return cc;
}
}
} else if (button.getData(NAME).equals(COPY_CHILD_COLUMNS)) {
String paramName = (String) button.getData(PARAMETER_NAME);
IElementParameter param = elem.getElementParameter(paramName);
IElementParameter processParam = elem.getElementParameterFromField(EParameterFieldType.PROCESS_TYPE);
IElementParameter processIdParam = processParam.getChildParameters().get(EParameterName.PROCESS_TYPE_PROCESS.getName());
String id = (String) processIdParam.getValue();
Item item = ItemCacheManager.getProcessItem(id);
Node node = (Node) elem;
copySchemaFromChildJob(node, item);
// pop up the schema dialog
MetadataDialog metaDialog = new MetadataDialog(composite.getShell(), node.getMetadataList().get(0), node, getCommandStack());
//$NON-NLS-1$
metaDialog.setText(Messages.getString("AbstractSchemaController.schemaOf") + node.getLabel());
if (metaDialog.open() == MetadataDialog.OK) {
IMetadataTable outputMetaData = metaDialog.getOutputMetaData();
return new ChangeMetadataCommand(node, param, null, outputMetaData);
}
}
return null;
}
use of org.talend.designer.core.ui.editor.cmd.ChangeMetadataCommand in project tdi-studio-se by Talend.
the class SynchronizeSchemaOnlyForPerlDemoMigrationTask method synchronizeSchema.
private boolean synchronizeSchema(IProcess2 process) {
List<? extends INode> graphicalNodes = process.getGraphicalNodes();
boolean modified = false;
for (INode node : graphicalNodes) {
if (syncComponents.contains(node.getComponent().getName())) {
IElementParameter param = node.getElementParameter(EParameterName.SCHEMA_TYPE.getName());
if (param != null) {
IMetadataTable meta = node.getMetadataFromConnector(param.getContext());
if (meta != null) {
IMetadataTable metaCopy = meta.clone(true);
ChangeMetadataCommand cmd = new ChangeMetadataCommand((Node) node, param, meta, metaCopy);
cmd.execute(true);
modified = true;
}
}
}
}
return modified;
}
use of org.talend.designer.core.ui.editor.cmd.ChangeMetadataCommand in project tdi-studio-se by Talend.
the class GuessSchemaController method runShadowProcess.
private void runShadowProcess(final Property property, final Node inputNode, final IContext selectContext, final IElementParameter switchParam) {
DatabaseConnection connt = TracesConnectionUtils.createConnection(connParameters);
String dbmsId = connt.getDbmsId();
if (dbmsId == null) {
Shell shell = Display.getCurrent().getActiveShell();
MessageDialog.openError(shell, "No info about DB found !", "Please choose the correct mapping file.\n Note: This is normal when using JDBC component");
MappingFileSelectDialog dialog = new MappingFileSelectDialog(shell);
dialog.open();
dbmsId = dialog.getSelectId();
}
GuessSchemaProcess gsp = new GuessSchemaProcess(property, inputNode, selectContext, memoSQL, info, part.getProcess());
try {
List<Integer> indexsForSameNamedColumn = new ArrayList<Integer>();
CsvArray array = gsp.run();
List<String[]> schemaContent = array.getRows();
List<String> columnLabels = new ArrayList<String>();
if (columns != null) {
columns.clear();
}
if (!schemaContent.isEmpty()) {
int numbOfColumn = schemaContent.get(0).length;
for (int i = 1; i <= numbOfColumn; i++) {
indexsForSameNamedColumn.clear();
Boolean b = false;
IMetadataColumn oneColum = new MetadataColumn();
// get the column name from the temp file genenrated by GuessSchemaProcess.java
String labelName = (schemaContent.get(0))[i - 1];
if (info != null && info.isHive()) {
if (labelName != null && labelName.indexOf(TalendTextUtils.JAVA_END_STRING) != -1) {
labelName = labelName.substring(labelName.lastIndexOf(TalendTextUtils.JAVA_END_STRING) + 1, labelName.length());
}
}
String name = labelName;
String sub = "";
String sub2 = "";
if (labelName != null && labelName.length() > 0 && labelName.startsWith("_")) {
//$NON-NLS-1$
sub = labelName.substring(1);
if (sub != null && sub.length() > 0) {
sub2 = sub.substring(1);
}
}
if (KeywordsValidator.isKeyword(labelName) || KeywordsValidator.isKeyword(sub) || KeywordsValidator.isKeyword(sub2)) {
labelName = "_" + labelName;
b = true;
}
// String label = labelName;
// findSameNamedColumnAndReplaceTheIndex(indexsForSameNamedColumn, i, oneColum, labelName);
oneColum.setLabel(MetadataToolHelper.validateColumnName(labelName, i, columnLabels));
// if (b && label != null && label.length() > 0 && label.startsWith("_")) { //$NON-NLS-1$
// String substring = label.substring(1);
// if (label.startsWith("_")
// && (KeywordsValidator.isKeyword(substring) || KeywordsValidator.isKeyword(sub) ||
// KeywordsValidator
// .isKeyword(sub2))) {
// label = substring;
// }
// }
oneColum.setOriginalDbColumnName(name);
if (schemaContent.size() > 5) {
oneColum.setPrecision(Integer.parseInt(schemaContent.get(2)[i - 1]));
oneColum.setLength(Integer.parseInt(schemaContent.get(3)[i - 1]));
}
try {
String talendType = null;
// to see if the language is java or perl
if (LanguageManager.getCurrentLanguage() == ECodeLanguage.JAVA) {
if (schemaContent.size() >= 5) {
talendType = MetadataTalendType.getMappingTypeRetriever(dbmsId).getDefaultSelectedTalendType(schemaContent.get(4)[i - 1]);
} else {
talendType = JavaTypesManager.STRING.getId();
}
} else {
if (schemaContent.size() >= 5) {
talendType = PerlDataTypeHelper.getNewTalendTypeOfValue(schemaContent.get(4)[i - 1]);
} else {
talendType = PerlTypesManager.STRING;
}
}
oneColum.setTalendType(talendType);
if (dbmsId != null) {
if (!TypesManager.checkDBType(dbmsId, oneColum.getTalendType(), oneColum.getType())) {
oneColum.setType(TypesManager.getDBTypeFromTalendType(dbmsId, oneColum.getTalendType()));
}
}
// oneColum.setTalendType(JavaTypesManager.STRING.getId());
} catch (Exception e) {
/*
* the table have no data at all ,to do nothing
*/
ExceptionHandler.process(e);
}
// get if a column is nullable from the temp file genenrated by GuessSchemaProcess.java
oneColum.setNullable((schemaContent.get(1))[i - 1].equals(Boolean.TRUE.toString()) ? true : false);
columns.add(oneColum);
columnLabels.add(oneColum.getLabel());
}
if (columns.size() > 0) {
IElementParameter dqRule = elem.getElementParameter("DQRULES_LIST");
if (dqRule != null) {
ITDQRuleService ruleService = null;
try {
ruleService = (ITDQRuleService) GlobalServiceRegister.getDefault().getService(ITDQRuleService.class);
} catch (RuntimeException e) {
// nothing to do
}
IElementParameter queryParam = elem.getElementParameter("QUERY");
if (ruleService != null && queryParam != null) {
ruleService.updateOriginalColumnNames(columns, queryParam);
}
}
}
IMetadataTable tempMetatable = new MetadataTable();
/* for bug 20973 */
if (tempMetatable.getTableName() == null) {
tempMetatable.setTableName(inputNode.getUniqueName());
}
IMetadataTable outputMetaCopy, originaleOutputTable;
String propertyName = "";
if (!btn.isDisposed()) {
propertyName = (String) btn.getData(PARAMETER_NAME);
}
IElementParameter param = inputNode.getElementParameter(propertyName);
for (IElementParameter eParam : elem.getElementParameters()) {
if (eParam.getContext() != null) {
param = eParam;
}
}
originaleOutputTable = inputNode.getMetadataFromConnector(param.getContext());
if (originaleOutputTable != null) {
outputMetaCopy = originaleOutputTable.clone();
}
tempMetatable.setListColumns(columns);
tempMetatable.setDbms(dbmsId);
MetadataDialog metaDialog = new MetadataDialog(composite.getShell(), tempMetatable, inputNode, getCommandStack());
if (metaDialog != null) {
//$NON-NLS-1$
metaDialog.setText(Messages.getString("AbstractSchemaController.schema.title", inputNode.getLabel()));
}
// ok pressed
if (metaDialog.open() == MetadataDialog.OK) {
outputMetaCopy = metaDialog.getOutputMetaData();
boolean modified = false;
if (!outputMetaCopy.sameMetadataAs(originaleOutputTable, IMetadataColumn.OPTIONS_NONE)) {
modified = true;
}
if (modified) {
if (switchParam != null) {
switchParam.setValue(Boolean.FALSE);
}
changeMetadataCommand = new ChangeMetadataCommand(inputNode, param, originaleOutputTable, outputMetaCopy);
changeMetadataCommand.execute();
}
}
}
} catch (ProcessorException e) {
ExtractMetaDataUtils.getInstance().closeConnection();
final String strExcepton = e.getMessage();
Display.getDefault().asyncExec(new Runnable() {
@Override
public void run() {
MessageDialog.openWarning(composite.getShell(), Messages.getString("GuessSchemaController.connectionError"), //$NON-NLS-1$
strExcepton);
}
});
ExceptionHandler.process(e);
}
}
use of org.talend.designer.core.ui.editor.cmd.ChangeMetadataCommand in project tdi-studio-se by Talend.
the class RetrieveSchemaHelper method retrieveSchemasCommand.
public static Command retrieveSchemasCommand(Node node) {
IElementParameter param = node.getElementParameter("SCHEMA");
IMetadataTable inputMeta = node.getMetadataFromConnector("FLOW");
IMetadataTable inputMetaCopy = inputMeta.clone(true);
IElementParameter outParam = node.getElementParameter("SCHEMA_OUT");
IMetadataTable outputMeta = node.getMetadataFromConnector(outParam.getContext());
IMetadataTable outputMetaCopy = outputMeta.clone(true);
File xmlFile = new File(TalendTextUtils.removeQuotes(node.getElementParameter("PATH_JOBDEF").getValue().toString()));
if (!xmlFile.exists())
try {
xmlFile.createNewFile();
} catch (IOException e1) {
ExceptionHandler.process(e1);
}
SAXReader saxReader = new SAXReader();
Document document;
AutoApi a = null;
try {
// get the schema file from server
a = new AutoApi();
String hostName = TalendTextUtils.removeQuotes(node.getElementParameter("HOSTNAME").getValue().toString());
int port = Integer.parseInt(TalendTextUtils.removeQuotes(node.getElementParameter("PORT").getValue().toString()));
String mandant = TalendTextUtils.removeQuotes(node.getElementParameter("MANDANT").getValue().toString());
String userName = TalendTextUtils.removeQuotes(node.getElementParameter("USERNAME").getValue().toString());
String passWord = TalendTextUtils.removeQuotes(node.getElementParameter("PASSWORD").getValue().toString());
String jobDir = TalendTextUtils.removeQuotes(node.getElementParameter("JOB_DIR").getValue().toString());
String jobName = TalendTextUtils.removeQuotes(node.getElementParameter("JOB_NAME").getValue().toString());
String jobDef = TalendTextUtils.removeQuotes(node.getElementParameter("PATH_JOBDEF").getValue().toString());
a.openConnection(hostName, port, mandant, userName, passWord);
a.getJobDefinitionFile(jobDir, jobName, jobDef);
document = saxReader.read(xmlFile);
List inputList = document.selectNodes("//Job//Lines//Line//Steps//Input//Sources//Source//Format//Fields//Field");
List inputMetaColumnList = new ArrayList<MetadataColumn>();
for (int i = 0; i < inputList.size(); i++) {
IMetadataColumn imc = new MetadataColumn();
DefaultElement de = (DefaultElement) inputList.get(i);
Element nameElement = de.element("Name");
imc.setLabel(nameElement.getData().toString());
Element lengthElement = de.element("Length");
if (!"".equals(lengthElement.getData().toString()) && !"0".equals(lengthElement.getData().toString())) {
imc.setLength(Integer.parseInt(lengthElement.getData().toString()));
}
Element typeElement = de.element("Type");
JavaType javaType = JavaTypesManager.getJavaTypeFromName(typeElement.getData().toString());
if (javaType != null) {
imc.setTalendType(javaType.getId());
} else {
imc.setTalendType(JavaTypesManager.STRING.getId());
}
inputMetaColumnList.add(imc);
}
inputMetaCopy.setListColumns(inputMetaColumnList);
List outputList = document.selectNodes("//Job//Lines//Line//Steps//Output//Targets//Target//Format//Fields//Field");
List outputMetaColumnList = new ArrayList<MetadataColumn>();
for (int i = 0; i < outputList.size(); i++) {
IMetadataColumn imc = new MetadataColumn();
DefaultElement de = (DefaultElement) outputList.get(i);
Element nameElement = de.element("Name");
imc.setLabel(nameElement.getData().toString());
Element lengthElement = de.element("Length");
if (!"".equals(lengthElement.getData().toString()) && !"0".equals(lengthElement.getData().toString())) {
imc.setLength(Integer.parseInt(lengthElement.getData().toString()));
}
Element typeElement = de.element("Type");
JavaType javaType = JavaTypesManager.getJavaTypeFromName(typeElement.getData().toString());
if (javaType != null) {
imc.setTalendType(javaType.getId());
} else {
imc.setTalendType(JavaTypesManager.STRING.getId());
}
outputMetaColumnList.add(imc);
}
outputMetaCopy.setListColumns(outputMetaColumnList);
// set advanced setting info
DefaultElement de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Input//Sources//Source//Format//FileInfo//Record//FieldSeparator");
int separator = Integer.parseInt(de.getData().toString());
node.getElementParameter("IN_FIELD_SEP").setValue(TalendTextUtils.addQuotes(new Character((char) separator).toString()));
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Input//Sources//Source//Format//FileInfo//Record//HeaderRecordCount");
node.getElementParameter("IN_HEADER_COUNT").setValue(de.getData().toString());
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Input//Sources//Source//Format//FileInfo//FileLocation//Directory");
node.getElementParameter("IN_DIR").setValue(TalendTextUtils.addQuotes(de.getData().toString()));
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Input//Sources//Source//Format//FileInfo//FileLocation//FileName");
node.getElementParameter("IN_FILENAME").setValue(TalendTextUtils.addQuotes(de.getData().toString()));
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Input//Sources//Source//Format//FileInfo//FileLocation");
node.getElementParameter("IN_MODE").setValue(de.attribute("Mode").getValue());
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Output//Targets//Target//Format//FileInfo//Record//FieldSeparator");
separator = Integer.parseInt(de.getData().toString());
node.getElementParameter("OUT_FIELD_SEP").setValue(TalendTextUtils.addQuotes(new Character((char) separator).toString()));
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Output//Targets//Target//Format//FileInfo//Record//HeaderRecordCount");
node.getElementParameter("OUT_HEADER_COUNT").setValue(de.getData().toString());
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Output//Targets//Target//Format//FileInfo//FileLocation//Directory");
node.getElementParameter("OUT_DIR").setValue(TalendTextUtils.addQuotes(de.getData().toString()));
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Output//Targets//Target//Format//FileInfo//FileLocation//FileName");
node.getElementParameter("OUT_FILENAME").setValue(TalendTextUtils.addQuotes(de.getData().toString()));
de = (DefaultElement) document.selectObject("//Job//Lines//Line//Steps//Output//Targets//Target//Format//FileInfo//FileLocation");
node.getElementParameter("OUT_MODE").setValue(de.attribute("Mode").getValue());
} catch (Exception e) {
ExceptionHandler.process(e);
} finally {
try {
a.closeConnection();
} catch (Exception e) {
ExceptionHandler.process(e);
}
}
CompoundCommand cc = new CompoundCommand();
cc.add(new ChangeMetadataCommand(node, param, inputMeta, inputMetaCopy));
cc.add(new ChangeMetadataCommand(node, param, outputMeta, outputMetaCopy));
return cc;
}
use of org.talend.designer.core.ui.editor.cmd.ChangeMetadataCommand in project tdi-studio-se by Talend.
the class GenericElementParameter method updateSchema.
private void updateSchema() {
IElement element = this.getElement();
if (element instanceof Node) {
Node node = (Node) element;
List<INodeConnector> connectors = node.getConnectorsFromType(EConnectionType.FLOW_MAIN);
for (INodeConnector connector : connectors) {
if (connector instanceof GenericNodeConnector) {
Connector componentConnector = ((GenericNodeConnector) connector).getComponentConnector();
Schema schema = null;
schema = getRootProperties().getSchema(componentConnector, ((GenericNodeConnector) connector).isOutput());
IMetadataTable mainTable = node.getMetadataFromConnector(connector.getName());
if (schema != null && mainTable != null) {
MetadataTable metadataTable = MetadataToolAvroHelper.convertFromAvro(schema);
IMetadataTable newTable = MetadataToolHelper.convert(metadataTable);
if (!mainTable.sameMetadataAs(newTable) || !newTable.sameMetadataAs(mainTable)) {
mainTable.setListColumns(newTable.getListColumns());
List<IElementParameter> schemaParameters = node.getElementParametersFromField(EParameterFieldType.SCHEMA_REFERENCE);
updateSchemaParameters(schemaParameters, connector.getName(), schema);
if (this.askPropagate == null && node.getOutgoingConnections().size() != 0) {
boolean hasPropagation = false;
for (IConnection connection : node.getOutgoingConnections()) {
if (connector.getName().equals(connection.getConnectorName())) {
if (isSchemaPropagated(connection.getTarget())) {
hasPropagation = true;
break;
}
}
}
if (hasPropagation) {
Display.getDefault().syncExec(new Runnable() {
@Override
public void run() {
askPropagate = ChangeMetadataCommand.askPropagate();
}
});
}
}
if (this.askPropagate != null && this.askPropagate) {
for (IConnection connection : node.getOutgoingConnections()) {
if (connector.getName().equals(connection.getConnectorName())) {
INode target = connection.getTarget();
if (!isSchemaPropagated(target)) {
continue;
}
ChangeMetadataCommand cmd = new ChangeMetadataCommand(target, null, null, newTable, null);
cmd.setPropagate(true);
IProcess process = node.getProcess();
if (process instanceof org.talend.designer.core.ui.editor.process.Process) {
CommandStack commandStack = ((org.talend.designer.core.ui.editor.process.Process) process).getCommandStack();
commandStack.execute(cmd);
}
}
}
}
}
}
}
}
this.askPropagate = null;
}
}
Aggregations