All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.atlas.hive.hook.events.AlterTableRename Maven / Gradle / Ivy

There is a newer version: 2.3.0
Show newest version
/**
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 * 

* http://www.apache.org/licenses/LICENSE-2.0 *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.atlas.hive.hook.events; import org.apache.atlas.hive.hook.AtlasHiveHookContext; import org.apache.atlas.model.instance.AtlasEntity; import org.apache.atlas.model.instance.AtlasEntity.AtlasEntitiesWithExtInfo; import org.apache.atlas.model.instance.AtlasEntity.AtlasEntityExtInfo; import org.apache.atlas.model.instance.AtlasEntity.AtlasEntityWithExtInfo; import org.apache.atlas.model.instance.AtlasObjectId; import org.apache.atlas.model.notification.HookNotification; import org.apache.atlas.model.notification.HookNotification.EntityPartialUpdateRequestV2; import org.apache.atlas.model.notification.HookNotification.EntityUpdateRequestV2; import org.apache.commons.collections.CollectionUtils; import org.apache.commons.lang3.StringUtils; import org.apache.hadoop.hive.metastore.events.AlterTableEvent; import org.apache.hadoop.hive.ql.hooks.Entity; import org.apache.hadoop.hive.ql.hooks.WriteEntity; import org.apache.hadoop.hive.ql.metadata.Table; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.*; public class AlterTableRename extends BaseHiveEvent { private static final Logger LOG = LoggerFactory.getLogger(AlterTableRename.class); public AlterTableRename(AtlasHiveHookContext context) { super(context); } @Override public List getNotificationMessages() throws Exception { return context.isMetastoreHook() ? getHiveMetastoreMessages() : getHiveMessages(); } public List getHiveMetastoreMessages() throws Exception { List ret = new ArrayList<>(); AlterTableEvent tblEvent = (AlterTableEvent) context.getMetastoreEvent(); Table oldTable = toTable(tblEvent.getOldTable()); Table newTable = toTable(tblEvent.getNewTable()); if (newTable == null) { LOG.error("AlterTableRename: renamed table not found in outputs list"); return ret; } processTables(oldTable, newTable, ret); return ret; } public List getHiveMessages() throws Exception { List ret = new ArrayList<>(); Table oldTable; Table newTable; if (CollectionUtils.isEmpty(getInputs())) { LOG.error("AlterTableRename: old-table not found in inputs list"); return ret; } oldTable = getInputs().iterator().next().getTable(); newTable = null; if (CollectionUtils.isNotEmpty(getOutputs())) { for (WriteEntity entity : getOutputs()) { if (entity.getType() == Entity.Type.TABLE) { newTable = entity.getTable(); //Hive sends with both old and new table names in the outputs which is weird. So skipping that with the below check if (StringUtils.equalsIgnoreCase(newTable.getDbName(), oldTable.getDbName()) && StringUtils.equalsIgnoreCase(newTable.getTableName(), oldTable.getTableName())) { newTable = null; continue; } newTable = getHive().getTable(newTable.getDbName(), newTable.getTableName()); break; } } } if (newTable == null) { LOG.error("AlterTableRename: renamed table not found in outputs list"); return ret; } processTables(oldTable, newTable, ret); return ret; } private void processTables(Table oldTable, Table newTable, List ret) throws Exception { AtlasEntityWithExtInfo oldTableEntity = toTableEntity(oldTable); AtlasEntityWithExtInfo renamedTableEntity = toTableEntity(newTable); if (oldTableEntity == null || renamedTableEntity == null) { return; } // update qualifiedName for all columns, partitionKeys, storageDesc String renamedTableQualifiedName = (String) renamedTableEntity.getEntity().getAttribute(ATTRIBUTE_QUALIFIED_NAME); renameColumns((List) oldTableEntity.getEntity().getRelationshipAttribute(ATTRIBUTE_COLUMNS), oldTableEntity, renamedTableQualifiedName, ret); renameColumns((List) oldTableEntity.getEntity().getRelationshipAttribute(ATTRIBUTE_PARTITION_KEYS), oldTableEntity, renamedTableQualifiedName, ret); renameStorageDesc(oldTableEntity, renamedTableEntity, ret); // set previous name as the alias renamedTableEntity.getEntity().setAttribute(ATTRIBUTE_ALIASES, Collections.singletonList(oldTable.getTableName())); // make a copy of renamedTableEntity to send as partial-update with no relationship attributes AtlasEntity renamedTableEntityForPartialUpdate = new AtlasEntity(renamedTableEntity.getEntity()); renamedTableEntityForPartialUpdate.setRelationshipAttributes(null); String oldTableQualifiedName = (String) oldTableEntity.getEntity().getAttribute(ATTRIBUTE_QUALIFIED_NAME); AtlasObjectId oldTableId = new AtlasObjectId(oldTableEntity.getEntity().getTypeName(), ATTRIBUTE_QUALIFIED_NAME, oldTableQualifiedName); // update qualifiedName and other attributes (like params - which include lastModifiedTime, lastModifiedBy) of the table ret.add(new EntityPartialUpdateRequestV2(getUserName(), oldTableId, new AtlasEntityWithExtInfo(renamedTableEntityForPartialUpdate))); // to handle cases where Atlas didn't have the oldTable, send a full update ret.add(new EntityUpdateRequestV2(getUserName(), new AtlasEntitiesWithExtInfo(renamedTableEntity))); // partial update relationship attribute ddl if (!context.isMetastoreHook()) { AtlasEntity ddlEntity = createHiveDDLEntity(renamedTableEntity.getEntity(), true); if (ddlEntity != null) { ret.add(new HookNotification.EntityCreateRequestV2(getUserName(), new AtlasEntitiesWithExtInfo(ddlEntity))); } } context.removeFromKnownTable(oldTableQualifiedName); } private void renameColumns(List columns, AtlasEntityExtInfo oldEntityExtInfo, String newTableQualifiedName, List notifications) { if (CollectionUtils.isNotEmpty(columns)) { for (AtlasObjectId columnId : columns) { AtlasEntity oldColumn = oldEntityExtInfo.getEntity(columnId.getGuid()); AtlasObjectId oldColumnId = new AtlasObjectId(oldColumn.getTypeName(), ATTRIBUTE_QUALIFIED_NAME, oldColumn.getAttribute(ATTRIBUTE_QUALIFIED_NAME)); AtlasEntity newColumn = new AtlasEntity(oldColumn.getTypeName(), ATTRIBUTE_QUALIFIED_NAME, getColumnQualifiedName(newTableQualifiedName, (String) oldColumn.getAttribute(ATTRIBUTE_NAME))); notifications.add(new EntityPartialUpdateRequestV2(getUserName(), oldColumnId, new AtlasEntityWithExtInfo(newColumn))); } } } private void renameStorageDesc(AtlasEntityWithExtInfo oldEntityExtInfo, AtlasEntityWithExtInfo newEntityExtInfo, List notifications) { AtlasEntity oldSd = getStorageDescEntity(oldEntityExtInfo); AtlasEntity newSd = new AtlasEntity(getStorageDescEntity(newEntityExtInfo)); // make a copy of newSd, since we will be setting relationshipAttributes to 'null' below // and we need relationship attributes later during entity full update if (oldSd != null && newSd != null) { AtlasObjectId oldSdId = new AtlasObjectId(oldSd.getTypeName(), ATTRIBUTE_QUALIFIED_NAME, oldSd.getAttribute(ATTRIBUTE_QUALIFIED_NAME)); newSd.removeAttribute(ATTRIBUTE_TABLE); newSd.setRelationshipAttributes(null); notifications.add(new EntityPartialUpdateRequestV2(getUserName(), oldSdId, new AtlasEntityWithExtInfo(newSd))); } } private AtlasEntity getStorageDescEntity(AtlasEntityWithExtInfo tableEntity) { AtlasEntity ret = null; if (tableEntity != null && tableEntity.getEntity() != null) { Object attrSdId = tableEntity.getEntity().getRelationshipAttribute(ATTRIBUTE_STORAGEDESC); if (attrSdId instanceof AtlasObjectId) { ret = tableEntity.getReferredEntity(((AtlasObjectId) attrSdId).getGuid()); } } return ret; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy