// ============================================================================ // // Copyright (C) 2006-2016 Talend Inc. - www.talend.com // // This source code is available under agreement available at // %InstallDIR%\features\org.talend.rcp.branding.%PRODUCTNAME%\%PRODUCTNAME%license.txt // // You should have received a copy of the agreement // along with this program; if not, write to Talend SA // 9 rue Pages 92150 Suresnes, France // // ============================================================================ package org.talend.dq.nodes.hadoopcluster; import java.util.List; import org.apache.commons.lang.StringUtils; import org.apache.log4j.Logger; import org.eclipse.core.runtime.IPath; import org.talend.commons.exception.PersistenceException; import org.talend.commons.utils.data.container.RootContainer; import org.talend.core.model.general.Project; import org.talend.core.model.properties.Item; import org.talend.core.model.repository.IRepositoryViewObject; import org.talend.core.repository.model.ProxyRepositoryFactory; import org.talend.cwm.management.i18n.Messages; import org.talend.dq.helper.HadoopClusterUtils; import org.talend.dq.helper.RepositoryNodeHelper; import org.talend.dq.nodes.DQFolderRepNode; import org.talend.repository.model.IRepositoryNode; import org.talend.repository.model.RepositoryNode; /** * created by yyin on 2015年4月24日 Detailled comment * */ public class HDFSOfHCFolderRepNode extends DQFolderRepNode { private static Logger log = Logger.getLogger(HDFSOfHCFolderRepNode.class); public HDFSOfHCFolderRepNode(IRepositoryViewObject object, RepositoryNode parent, ENodeType type, org.talend.core.model.general.Project inWhichProject) { super(object, parent, type, inWhichProject); } @Override public String getDisplayText() { return Messages.getString("HDFSOfHCFolderRepNode.displayText"); //$NON-NLS-1$ } /* * (non-Javadoc) * * @see org.talend.repository.model.RepositoryNode#getChildren() */ @Override public List<IRepositoryNode> getChildren() { return getChildren(false); } /* * (non-Javadoc) * * @see org.talend.dq.nodes.DQFolderRepNode#getChildrenForProject(boolean, org.talend.core.model.general.Project) */ @Override public void getChildrenForProject(boolean withDeleted, Project project) throws PersistenceException { // this folder path is: hadoop/hdfs, its parent's path is: hadoop/hadoopcluster IPath path = getPathOfHDFSFolder(); Item clusterConnectionItem = getParent().getObject().getProperty().getItem(); String clusterId = clusterConnectionItem.getProperty().getId(); RootContainer<String, IRepositoryViewObject> tdqViewObjects = ProxyRepositoryFactory.getInstance() .getTdqRepositoryViewObjects(project, HadoopClusterUtils.getDefault().getHDFSType(), path.toString()); for (IRepositoryViewObject viewObject : tdqViewObjects.getMembers()) { if (!withDeleted && viewObject.isDeleted()) { continue; } HDFSOfHCConnectionNode repNode = null; // check if this hdfs's relativeHadoopClusterId = this hadoop cluster's id if (viewObject != null && viewObject.getProperty() != null) { String hcId = HadoopClusterUtils.getDefault().getHadoopClusterID(viewObject); if (!StringUtils.equals(clusterId, hcId)) { continue; } } try { repNode = new HDFSOfHCConnectionNode(viewObject, this, ENodeType.REPOSITORY_ELEMENT, project); } catch (Exception e) { log.error(e, e); continue; } repNode.setProperties(EProperties.LABEL, viewObject.getLabel()); // repNode.setProperties(EProperties.CONTENT_TYPE, ERepositoryObjectType.METADATA_CONNECTIONS); viewObject.setRepositoryNode(repNode); super.getChildren().add(repNode); } } private IPath getPathOfHDFSFolder() { IPath path = RepositoryNodeHelper.getPath(this.getParent());// =metadata/hadoop/hadoopcluster // change it to: metadata/hadoop/hdfs path = path.removeLastSegments(1); path = path.append("hdfs"); //$NON-NLS-1$ return path; } }