This repository has been archived by the owner on Jan 27, 2025. It is now read-only.
forked from datahub-project/datahub
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(ingest/tableau): emit status aspects + streamline stateful inges…
…tion (datahub-project#6188)
- Loading branch information
Showing
6 changed files
with
223 additions
and
190 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
71 changes: 71 additions & 0 deletions
71
metadata-ingestion/src/datahub/utilities/source_helpers.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
from typing import Callable, Iterable, Optional, Set | ||
|
||
from datahub.emitter.mcp import MetadataChangeProposalWrapper | ||
from datahub.ingestion.api.workunit import MetadataWorkUnit | ||
from datahub.ingestion.source.state.stale_entity_removal_handler import ( | ||
StaleEntityRemovalHandler, | ||
) | ||
from datahub.metadata.schema_classes import MetadataChangeEventClass, StatusClass | ||
from datahub.utilities.urns.urn import guess_entity_type | ||
|
||
|
||
def auto_status_aspect( | ||
stream: Iterable[MetadataWorkUnit], | ||
) -> Iterable[MetadataWorkUnit]: | ||
""" | ||
For all entities that don't have a status aspect, add one with removed set to false. | ||
""" | ||
|
||
all_urns: Set[str] = set() | ||
status_urns: Set[str] = set() | ||
for wu in stream: | ||
urn = wu.get_urn() | ||
if isinstance(wu.metadata, MetadataChangeEventClass): | ||
if any( | ||
isinstance(aspect, StatusClass) | ||
for aspect in wu.metadata.proposedSnapshot.aspects | ||
): | ||
status_urns.add(urn) | ||
elif isinstance(wu.metadata, MetadataChangeProposalWrapper): | ||
if isinstance(wu.metadata.aspect, StatusClass): | ||
status_urns.add(urn) | ||
else: | ||
raise ValueError(f"Unexpected type {type(wu.metadata)}") | ||
|
||
yield wu | ||
|
||
for urn in all_urns - status_urns: | ||
yield MetadataChangeProposalWrapper( | ||
entityUrn=urn, | ||
aspect=StatusClass(removed=False), | ||
).as_workunit() | ||
|
||
|
||
def _default_entity_type_fn(wu: MetadataWorkUnit) -> Optional[str]: | ||
urn = wu.get_urn() | ||
entity_type = guess_entity_type(urn) | ||
return entity_type | ||
|
||
|
||
def auto_stale_entity_removal( | ||
stale_entity_removal_handler: StaleEntityRemovalHandler, | ||
stream: Iterable[MetadataWorkUnit], | ||
entity_type_fn: Callable[ | ||
[MetadataWorkUnit], Optional[str] | ||
] = _default_entity_type_fn, | ||
) -> Iterable[MetadataWorkUnit]: | ||
""" | ||
Record all entities that are found, and emit removals for any that disappeared in this run. | ||
""" | ||
|
||
for wu in stream: | ||
urn = wu.get_urn() | ||
|
||
entity_type = entity_type_fn(wu) | ||
if entity_type is not None: | ||
stale_entity_removal_handler.add_entity_to_state(entity_type, urn) | ||
|
||
yield wu | ||
|
||
# Clean up stale entities. | ||
yield from stale_entity_removal_handler.gen_removed_entity_workunits() |
Oops, something went wrong.