mirror of
				https://github.com/datahub-project/datahub.git
				synced 2025-10-26 00:14:53 +00:00 
			
		
		
		
	
		
			
	
	
		
			49 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
		
		
			
		
	
	
			49 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
|   | import json | ||
|  | 
 | ||
|  | from datahub.emitter.rest_emitter import DatahubRestEmitter | ||
|  | from datahub.metadata.schema_classes import ( | ||
|  |     ChangeTypeClass, | ||
|  |     GenericAspectClass, | ||
|  |     MetadataChangeProposalClass, | ||
|  | ) | ||
|  | 
 | ||
|  | dq_aspect = { | ||
|  |     "rules": [ | ||
|  |         { | ||
|  |             "field": "my_event_data", | ||
|  |             "isFieldLevel": False, | ||
|  |             "type": "isNull", | ||
|  |             "checkDefinition": "n/a", | ||
|  |             "url": "https://github.com/datahub-project/datahub/blob/master/checks/nonNull.sql", | ||
|  |         }, | ||
|  |         { | ||
|  |             "field": "timestamp", | ||
|  |             "isFieldLevel": True, | ||
|  |             "type": "increasing", | ||
|  |             "checkDefinition": "n/a", | ||
|  |             "url": "https://github.com/datahub-project/datahub/blob/master/checks/increasing.sql", | ||
|  |         }, | ||
|  |     ] | ||
|  | } | ||
|  | 
 | ||
|  | emitter: DatahubRestEmitter = DatahubRestEmitter(gms_server="http://localhost:8080") | ||
|  | 
 | ||
|  | dataset_urn = "urn:li:dataset:(urn:li:dataPlatform:hive,logging_events,PROD)" | ||
|  | mcp_raw: MetadataChangeProposalClass = MetadataChangeProposalClass( | ||
|  |     entityType="dataset", | ||
|  |     entityUrn=dataset_urn, | ||
|  |     changeType=ChangeTypeClass.UPSERT, | ||
|  |     aspectName="customDataQualityRules", | ||
|  |     aspect=GenericAspectClass( | ||
|  |         contentType="application/json", | ||
|  |         value=json.dumps(dq_aspect).encode("utf-8"), | ||
|  |     ), | ||
|  | ) | ||
|  | 
 | ||
|  | try: | ||
|  |     emitter.emit(mcp_raw) | ||
|  |     print("Successfully wrote to DataHub") | ||
|  | except Exception as e: | ||
|  |     print("Failed to write to DataHub") | ||
|  |     raise e |