openmetadata-ingestion 1.3.3.0rc1__py3-none-any.whl → 1.4.0.0rc1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of openmetadata-ingestion might be problematic. Click here for more details.

Files changed (961) hide show
  1. metadata/automations/runner.py +9 -0
  2. metadata/cli/backup.py +7 -0
  3. metadata/cli/lineage.py +5 -1
  4. metadata/cli/restore.py +7 -0
  5. metadata/cmd.py +2 -152
  6. metadata/data_insight/processor/reports/cost_analysis_report_data_processor.py +0 -1
  7. metadata/data_quality/api/models.py +1 -0
  8. metadata/data_quality/processor/test_case_runner.py +9 -2
  9. metadata/data_quality/source/test_suite.py +6 -1
  10. metadata/data_quality/validations/base_test_handler.py +1 -1
  11. metadata/data_quality/validations/column/base/columnValuesMissingCount.py +4 -1
  12. metadata/data_quality/validations/column/sqlalchemy/columnValuesToBeUnique.py +28 -17
  13. metadata/data_quality/validations/mixins/sqa_validator_mixin.py +4 -1
  14. metadata/data_quality/validations/table/base/tableCustomSQLQuery.py +1 -1
  15. metadata/examples/workflows/airbyte.yaml +1 -0
  16. metadata/examples/workflows/airflow.yaml +1 -1
  17. metadata/examples/workflows/airflow_backend.yaml +1 -1
  18. metadata/examples/workflows/airflow_postgres.yaml +1 -1
  19. metadata/examples/workflows/amundsen.yaml +1 -0
  20. metadata/examples/workflows/athena.yaml +1 -0
  21. metadata/examples/workflows/athena_lineage.yaml +1 -1
  22. metadata/examples/workflows/athena_usage.yaml +1 -0
  23. metadata/examples/workflows/atlas.yaml +1 -0
  24. metadata/examples/workflows/azuresql.yaml +1 -0
  25. metadata/examples/workflows/azuresql_lineage.yaml +1 -0
  26. metadata/examples/workflows/azuresql_usage.yaml +1 -0
  27. metadata/examples/workflows/bigquery.yaml +1 -0
  28. metadata/examples/workflows/bigquery_lineage.yaml +1 -0
  29. metadata/examples/workflows/bigquery_profiler.yaml +1 -0
  30. metadata/examples/workflows/bigquery_usage.yaml +1 -0
  31. metadata/examples/workflows/bigtable.yaml +1 -1
  32. metadata/examples/workflows/clickhouse.yaml +1 -0
  33. metadata/examples/workflows/clickhouse_lineage.yaml +1 -0
  34. metadata/examples/workflows/clickhouse_usage.yaml +1 -0
  35. metadata/examples/workflows/couchbase.yaml +1 -1
  36. metadata/examples/workflows/dagster.yaml +1 -0
  37. metadata/examples/workflows/data_insight.yaml +1 -1
  38. metadata/examples/workflows/databricks.yaml +1 -0
  39. metadata/examples/workflows/databricks_lineage.yaml +1 -0
  40. metadata/examples/workflows/databricks_pipeline.yaml +1 -0
  41. metadata/examples/workflows/databricks_usage.yaml +1 -0
  42. metadata/examples/workflows/datalake_azure_client_secret.yaml +1 -0
  43. metadata/examples/workflows/datalake_gcs.yaml +1 -0
  44. metadata/examples/workflows/datalake_profiler.yaml +1 -0
  45. metadata/examples/workflows/datalake_s3.yaml +1 -0
  46. metadata/examples/workflows/db2.yaml +1 -0
  47. metadata/examples/workflows/db2_profiler.yaml +1 -0
  48. metadata/examples/workflows/dbt.yaml +2 -0
  49. metadata/examples/workflows/deltalake.yaml +1 -0
  50. metadata/examples/workflows/domodashboard.yaml +1 -0
  51. metadata/examples/workflows/dynamodb.yaml +1 -0
  52. metadata/examples/workflows/elasticsearch.yaml +1 -1
  53. metadata/examples/workflows/fivetran.yaml +1 -0
  54. metadata/examples/workflows/glue.yaml +1 -0
  55. metadata/examples/workflows/gluepipeline.yaml +1 -0
  56. metadata/examples/workflows/hive.yaml +1 -0
  57. metadata/examples/workflows/impala.yaml +1 -0
  58. metadata/examples/workflows/kafka.yaml +1 -1
  59. metadata/examples/workflows/kinesis.yaml +1 -1
  60. metadata/examples/workflows/lightdash.yaml +1 -0
  61. metadata/examples/workflows/looker.yaml +1 -0
  62. metadata/examples/workflows/mariadb.yaml +1 -0
  63. metadata/examples/workflows/metabase.yaml +1 -0
  64. metadata/examples/workflows/mlflow.yaml +1 -0
  65. metadata/examples/workflows/mode.yaml +3 -1
  66. metadata/examples/workflows/mongodb.yaml +1 -0
  67. metadata/examples/workflows/mssql.yaml +1 -0
  68. metadata/examples/workflows/mssql_lineage.yaml +1 -0
  69. metadata/examples/workflows/mssql_usage.yaml +1 -0
  70. metadata/examples/workflows/mstr.yaml +1 -0
  71. metadata/examples/workflows/mysql.yaml +1 -0
  72. metadata/examples/workflows/mysql_profiler.yaml +1 -0
  73. metadata/examples/workflows/openmetadata.yaml +1 -0
  74. metadata/examples/workflows/oracle.yaml +1 -0
  75. metadata/examples/workflows/oracle_lineage.yaml +1 -1
  76. metadata/examples/workflows/oracle_usage.yaml +1 -0
  77. metadata/examples/workflows/pinotdb.yaml +1 -0
  78. metadata/examples/workflows/postgres.yaml +1 -0
  79. metadata/examples/workflows/postgres_lineage.yaml +1 -1
  80. metadata/examples/workflows/postgres_usage.yaml +1 -1
  81. metadata/examples/workflows/powerbi.yaml +52 -0
  82. metadata/examples/workflows/presto.yaml +1 -0
  83. metadata/examples/workflows/qlik_sense.yaml +6 -4
  84. metadata/examples/workflows/qlikcloud.yaml +31 -0
  85. metadata/examples/workflows/query_log_usage.yaml +1 -0
  86. metadata/examples/workflows/quicksight.yaml +1 -0
  87. metadata/examples/workflows/redash.yaml +1 -0
  88. metadata/examples/workflows/redpanda.yaml +1 -0
  89. metadata/examples/workflows/redshift.yaml +1 -0
  90. metadata/examples/workflows/redshift_lineage.yaml +1 -0
  91. metadata/examples/workflows/redshift_profiler.yaml +1 -0
  92. metadata/examples/workflows/redshift_usage.yaml +1 -0
  93. metadata/examples/workflows/sagemaker.yaml +1 -1
  94. metadata/examples/workflows/salesforce.yaml +1 -0
  95. metadata/examples/workflows/sas.yaml +1 -1
  96. metadata/examples/workflows/singlestore.yaml +1 -0
  97. metadata/examples/workflows/snowflake.yaml +1 -0
  98. metadata/examples/workflows/snowflake_lineage.yaml +1 -0
  99. metadata/examples/workflows/snowflake_usage.yaml +1 -0
  100. metadata/examples/workflows/spline.yaml +5 -4
  101. metadata/examples/workflows/sqlite.yaml +1 -0
  102. metadata/examples/workflows/superset.yaml +1 -0
  103. metadata/examples/workflows/tableau.yaml +1 -0
  104. metadata/examples/workflows/test_suite.yaml +13 -16
  105. metadata/examples/workflows/trino.yaml +1 -0
  106. metadata/examples/workflows/trino_lineage.yaml +1 -0
  107. metadata/examples/workflows/trino_usage.yaml +1 -0
  108. metadata/examples/workflows/unity_catalog.yaml +1 -1
  109. metadata/examples/workflows/unity_catalog_lineage.yaml +1 -1
  110. metadata/examples/workflows/unity_catalog_usage.yaml +1 -1
  111. metadata/examples/workflows/vertica.yaml +1 -0
  112. metadata/generated/antlr/EntityLinkLexer.py +354 -349
  113. metadata/generated/schema/analytics/__init__.py +1 -1
  114. metadata/generated/schema/analytics/basic.py +1 -1
  115. metadata/generated/schema/analytics/reportData.py +1 -1
  116. metadata/generated/schema/analytics/reportDataType/__init__.py +1 -1
  117. metadata/generated/schema/analytics/reportDataType/aggregatedCostAnalysisReportData.py +1 -1
  118. metadata/generated/schema/analytics/reportDataType/entityReportData.py +1 -1
  119. metadata/generated/schema/analytics/reportDataType/rawCostAnalysisReportData.py +1 -1
  120. metadata/generated/schema/analytics/reportDataType/webAnalyticEntityViewReportData.py +1 -1
  121. metadata/generated/schema/analytics/reportDataType/webAnalyticUserActivityReportData.py +1 -1
  122. metadata/generated/schema/analytics/webAnalyticEvent.py +1 -1
  123. metadata/generated/schema/analytics/webAnalyticEventData.py +1 -1
  124. metadata/generated/schema/analytics/webAnalyticEventType/__init__.py +1 -1
  125. metadata/generated/schema/analytics/webAnalyticEventType/customEvent.py +1 -1
  126. metadata/generated/schema/analytics/webAnalyticEventType/pageViewEvent.py +1 -1
  127. metadata/generated/schema/api/__init__.py +1 -1
  128. metadata/generated/schema/api/addGlossaryToAssetsRequest.py +1 -1
  129. metadata/generated/schema/api/analytics/__init__.py +1 -1
  130. metadata/generated/schema/api/analytics/createWebAnalyticEvent.py +1 -1
  131. metadata/generated/schema/api/automations/__init__.py +1 -1
  132. metadata/generated/schema/api/automations/createWorkflow.py +1 -1
  133. metadata/generated/schema/api/bulkAssets.py +1 -1
  134. metadata/generated/schema/api/classification/__init__.py +1 -1
  135. metadata/generated/schema/api/classification/createClassification.py +2 -3
  136. metadata/generated/schema/api/classification/createTag.py +2 -3
  137. metadata/generated/schema/api/classification/loadTags.py +1 -1
  138. metadata/generated/schema/api/createBot.py +1 -1
  139. metadata/generated/schema/api/createEventPublisherJob.py +1 -1
  140. metadata/generated/schema/api/createType.py +1 -1
  141. metadata/generated/schema/api/data/__init__.py +1 -1
  142. metadata/generated/schema/api/data/createChart.py +1 -1
  143. metadata/generated/schema/api/data/createContainer.py +4 -1
  144. metadata/generated/schema/api/data/createCustomProperty.py +1 -1
  145. metadata/generated/schema/api/data/createDashboard.py +1 -1
  146. metadata/generated/schema/api/data/createDashboardDataModel.py +1 -1
  147. metadata/generated/schema/api/data/createDatabase.py +1 -1
  148. metadata/generated/schema/api/data/createDatabaseSchema.py +1 -1
  149. metadata/generated/schema/api/data/createGlossary.py +1 -1
  150. metadata/generated/schema/api/data/createGlossaryTerm.py +1 -1
  151. metadata/generated/schema/api/data/createMlModel.py +1 -1
  152. metadata/generated/schema/api/data/createPipeline.py +1 -1
  153. metadata/generated/schema/api/data/createQuery.py +1 -1
  154. metadata/generated/schema/api/data/createSearchIndex.py +1 -1
  155. metadata/generated/schema/api/data/createStoredProcedure.py +1 -1
  156. metadata/generated/schema/api/data/createTable.py +1 -1
  157. metadata/generated/schema/api/data/createTableProfile.py +1 -1
  158. metadata/generated/schema/api/data/createTopic.py +1 -1
  159. metadata/generated/schema/api/data/loadGlossary.py +1 -1
  160. metadata/generated/schema/api/data/restoreEntity.py +1 -1
  161. metadata/generated/schema/api/dataInsight/__init__.py +1 -1
  162. metadata/generated/schema/api/dataInsight/createDataInsightChart.py +1 -1
  163. metadata/generated/schema/api/dataInsight/kpi/__init__.py +1 -1
  164. metadata/generated/schema/api/dataInsight/kpi/createKpiRequest.py +1 -1
  165. metadata/generated/schema/api/docStore/__init__.py +1 -1
  166. metadata/generated/schema/api/docStore/createDocument.py +1 -1
  167. metadata/generated/schema/api/domains/__init__.py +1 -1
  168. metadata/generated/schema/api/domains/createDataProduct.py +1 -1
  169. metadata/generated/schema/api/domains/createDomain.py +1 -1
  170. metadata/generated/schema/api/feed/__init__.py +1 -1
  171. metadata/generated/schema/api/feed/closeTask.py +1 -1
  172. metadata/generated/schema/api/feed/createPost.py +1 -1
  173. metadata/generated/schema/api/feed/createSuggestion.py +1 -1
  174. metadata/generated/schema/api/feed/createThread.py +1 -1
  175. metadata/generated/schema/api/feed/resolveTask.py +1 -1
  176. metadata/generated/schema/api/feed/threadCount.py +1 -1
  177. metadata/generated/schema/api/lineage/__init__.py +1 -1
  178. metadata/generated/schema/api/lineage/addLineage.py +1 -1
  179. metadata/generated/schema/api/openMetadataServerVersion.py +1 -1
  180. metadata/generated/schema/api/policies/__init__.py +1 -1
  181. metadata/generated/schema/api/policies/createPolicy.py +1 -1
  182. metadata/generated/schema/api/services/__init__.py +1 -1
  183. metadata/generated/schema/api/services/createDashboardService.py +1 -1
  184. metadata/generated/schema/api/services/createDatabaseService.py +1 -1
  185. metadata/generated/schema/api/services/createMessagingService.py +1 -1
  186. metadata/generated/schema/api/services/createMetadataService.py +1 -1
  187. metadata/generated/schema/api/services/createMlModelService.py +1 -1
  188. metadata/generated/schema/api/services/createPipelineService.py +1 -1
  189. metadata/generated/schema/api/services/createSearchService.py +1 -1
  190. metadata/generated/schema/api/services/createStorageService.py +1 -1
  191. metadata/generated/schema/api/services/ingestionPipelines/__init__.py +1 -1
  192. metadata/generated/schema/api/services/ingestionPipelines/createIngestionPipeline.py +1 -1
  193. metadata/generated/schema/api/setOwner.py +1 -1
  194. metadata/generated/schema/api/teams/__init__.py +1 -1
  195. metadata/generated/schema/api/teams/createPersona.py +1 -1
  196. metadata/generated/schema/api/teams/createRole.py +1 -1
  197. metadata/generated/schema/api/teams/createTeam.py +1 -1
  198. metadata/generated/schema/api/teams/createUser.py +1 -1
  199. metadata/generated/schema/api/tests/__init__.py +1 -1
  200. metadata/generated/schema/api/tests/createCustomMetric.py +1 -1
  201. metadata/generated/schema/api/tests/createLogicalTestCases.py +1 -1
  202. metadata/generated/schema/api/tests/createTestCase.py +1 -1
  203. metadata/generated/schema/api/tests/createTestCaseResolutionStatus.py +1 -1
  204. metadata/generated/schema/api/tests/createTestDefinition.py +1 -1
  205. metadata/generated/schema/api/tests/createTestSuite.py +1 -1
  206. metadata/generated/schema/api/voteRequest.py +1 -1
  207. metadata/generated/schema/auth/__init__.py +1 -1
  208. metadata/generated/schema/auth/basicAuth.py +1 -1
  209. metadata/generated/schema/auth/basicLoginRequest.py +1 -1
  210. metadata/generated/schema/auth/changePasswordRequest.py +1 -1
  211. metadata/generated/schema/auth/createPersonalToken.py +1 -1
  212. metadata/generated/schema/auth/emailRequest.py +1 -1
  213. metadata/generated/schema/auth/emailVerificationToken.py +1 -1
  214. metadata/generated/schema/auth/generateToken.py +1 -1
  215. metadata/generated/schema/auth/jwtAuth.py +1 -1
  216. metadata/generated/schema/auth/loginRequest.py +1 -1
  217. metadata/generated/schema/auth/logoutRequest.py +1 -1
  218. metadata/generated/schema/auth/passwordResetRequest.py +1 -1
  219. metadata/generated/schema/auth/passwordResetToken.py +1 -1
  220. metadata/generated/schema/auth/personalAccessToken.py +1 -1
  221. metadata/generated/schema/auth/refreshToken.py +1 -1
  222. metadata/generated/schema/auth/registrationRequest.py +1 -1
  223. metadata/generated/schema/auth/revokePersonalToken.py +1 -1
  224. metadata/generated/schema/auth/revokeToken.py +1 -1
  225. metadata/generated/schema/auth/serviceTokenEnum.py +1 -1
  226. metadata/generated/schema/auth/ssoAuth.py +1 -1
  227. metadata/generated/schema/auth/tokenRefreshRequest.py +1 -1
  228. metadata/generated/schema/configuration/__init__.py +1 -1
  229. metadata/generated/schema/configuration/appsPrivateConfiguration.py +1 -1
  230. metadata/generated/schema/configuration/authConfig.py +1 -1
  231. metadata/generated/schema/configuration/authenticationConfiguration.py +1 -1
  232. metadata/generated/schema/configuration/authorizerConfiguration.py +4 -1
  233. metadata/generated/schema/configuration/changeEventConfiguration.py +1 -1
  234. metadata/generated/schema/configuration/dataQualityConfiguration.py +1 -1
  235. metadata/generated/schema/configuration/elasticSearchConfiguration.py +4 -1
  236. metadata/generated/schema/configuration/eventHandlerConfiguration.py +1 -1
  237. metadata/generated/schema/configuration/fernetConfiguration.py +1 -1
  238. metadata/generated/schema/configuration/jwtTokenConfiguration.py +1 -1
  239. metadata/generated/schema/configuration/kafkaEventConfiguration.py +1 -1
  240. metadata/generated/schema/configuration/ldapConfiguration.py +1 -1
  241. metadata/generated/schema/configuration/ldapTrustStoreConfig/__init__.py +1 -1
  242. metadata/generated/schema/configuration/ldapTrustStoreConfig/customTrustManagerConfig.py +1 -1
  243. metadata/generated/schema/configuration/ldapTrustStoreConfig/hostNameConfig.py +1 -1
  244. metadata/generated/schema/configuration/ldapTrustStoreConfig/jvmDefaultConfig.py +1 -1
  245. metadata/generated/schema/configuration/ldapTrustStoreConfig/trustAllConfig.py +1 -1
  246. metadata/generated/schema/configuration/ldapTrustStoreConfig/truststoreConfig.py +1 -1
  247. metadata/generated/schema/configuration/loginConfiguration.py +1 -1
  248. metadata/generated/schema/configuration/logoConfiguration.py +1 -1
  249. metadata/generated/schema/configuration/pipelineServiceClientConfiguration.py +1 -1
  250. metadata/generated/schema/configuration/profilerConfiguration.py +66 -0
  251. metadata/generated/schema/configuration/slackAppConfiguration.py +1 -1
  252. metadata/generated/schema/configuration/taskNotificationConfiguration.py +1 -1
  253. metadata/generated/schema/configuration/testResultNotificationConfiguration.py +1 -1
  254. metadata/generated/schema/configuration/themeConfiguration.py +32 -0
  255. metadata/generated/schema/configuration/uiThemePreference.py +23 -0
  256. metadata/generated/schema/dataInsight/__init__.py +1 -1
  257. metadata/generated/schema/dataInsight/dataInsightChart.py +1 -1
  258. metadata/generated/schema/dataInsight/dataInsightChartResult.py +1 -1
  259. metadata/generated/schema/dataInsight/kpi/__init__.py +1 -1
  260. metadata/generated/schema/dataInsight/kpi/basic.py +1 -1
  261. metadata/generated/schema/dataInsight/kpi/kpi.py +1 -1
  262. metadata/generated/schema/dataInsight/type/__init__.py +1 -1
  263. metadata/generated/schema/dataInsight/type/aggregatedUnusedAssetsCount.py +1 -1
  264. metadata/generated/schema/dataInsight/type/aggregatedUnusedAssetsSize.py +1 -1
  265. metadata/generated/schema/dataInsight/type/aggregatedUsedVsUnusedAssetsCount.py +1 -1
  266. metadata/generated/schema/dataInsight/type/aggregatedUsedVsUnusedAssetsSize.py +1 -1
  267. metadata/generated/schema/dataInsight/type/dailyActiveUsers.py +1 -1
  268. metadata/generated/schema/dataInsight/type/mostActiveUsers.py +1 -1
  269. metadata/generated/schema/dataInsight/type/mostViewedEntities.py +1 -1
  270. metadata/generated/schema/dataInsight/type/pageViewsByEntities.py +1 -1
  271. metadata/generated/schema/dataInsight/type/percentageOfEntitiesWithDescriptionByType.py +1 -1
  272. metadata/generated/schema/dataInsight/type/percentageOfEntitiesWithOwnerByType.py +1 -1
  273. metadata/generated/schema/dataInsight/type/percentageOfServicesWithDescription.py +1 -1
  274. metadata/generated/schema/dataInsight/type/percentageOfServicesWithOwner.py +1 -1
  275. metadata/generated/schema/dataInsight/type/totalEntitiesByTier.py +1 -1
  276. metadata/generated/schema/dataInsight/type/totalEntitiesByType.py +1 -1
  277. metadata/generated/schema/dataInsight/type/unusedAssets.py +1 -1
  278. metadata/generated/schema/email/__init__.py +1 -1
  279. metadata/generated/schema/email/emailRequest.py +1 -1
  280. metadata/generated/schema/email/smtpSettings.py +1 -1
  281. metadata/generated/schema/entity/__init__.py +1 -1
  282. metadata/generated/schema/entity/applications/__init__.py +1 -1
  283. metadata/generated/schema/entity/applications/app.py +1 -1
  284. metadata/generated/schema/entity/applications/appRunRecord.py +1 -1
  285. metadata/generated/schema/entity/applications/configuration/__init__.py +1 -1
  286. metadata/generated/schema/entity/applications/configuration/applicationConfig.py +3 -3
  287. metadata/generated/schema/entity/applications/configuration/external/__init__.py +1 -1
  288. metadata/generated/schema/entity/applications/configuration/external/automator/__init__.py +5 -0
  289. metadata/generated/schema/entity/applications/configuration/external/automator/addDescriptionAction.py +36 -0
  290. metadata/generated/schema/entity/applications/configuration/external/automator/addDomainAction.py +31 -0
  291. metadata/generated/schema/entity/applications/configuration/external/automator/addOwnerAction.py +31 -0
  292. metadata/generated/schema/entity/applications/configuration/external/automator/addTagsAction.py +36 -0
  293. metadata/generated/schema/entity/applications/configuration/external/automator/addTierAction.py +31 -0
  294. metadata/generated/schema/entity/applications/configuration/external/automator/lineagePropagationAction.py +28 -0
  295. metadata/generated/schema/entity/applications/configuration/external/automator/mlTaggingAction.py +22 -0
  296. metadata/generated/schema/entity/applications/configuration/external/automator/removeDescriptionAction.py +30 -0
  297. metadata/generated/schema/entity/applications/configuration/external/automator/removeDomainAction.py +22 -0
  298. metadata/generated/schema/entity/applications/configuration/external/automator/removeOwnerAction.py +22 -0
  299. metadata/generated/schema/entity/applications/configuration/external/automator/removeTagsAction.py +31 -0
  300. metadata/generated/schema/entity/applications/configuration/external/automator/removeTierAction.py +22 -0
  301. metadata/generated/schema/entity/applications/configuration/external/automatorAppConfig.py +75 -0
  302. metadata/generated/schema/entity/applications/configuration/external/metaPilotAppConfig.py +1 -1
  303. metadata/generated/schema/entity/applications/configuration/internal/__init__.py +1 -1
  304. metadata/generated/schema/entity/applications/configuration/internal/dataInsightsAppConfig.py +1 -1
  305. metadata/generated/schema/entity/applications/configuration/internal/dataInsightsReportAppConfig.py +1 -1
  306. metadata/generated/schema/entity/applications/configuration/internal/searchIndexingAppConfig.py +1 -1
  307. metadata/generated/schema/entity/applications/configuration/private/external/__init__.py +1 -1
  308. metadata/generated/schema/entity/applications/configuration/private/external/metaPilotAppPrivateConfig.py +1 -1
  309. metadata/generated/schema/entity/applications/createAppRequest.py +1 -1
  310. metadata/generated/schema/entity/applications/jobStatus.py +1 -1
  311. metadata/generated/schema/entity/applications/liveExecutionContext.py +1 -1
  312. metadata/generated/schema/entity/applications/marketplace/__init__.py +1 -1
  313. metadata/generated/schema/entity/applications/marketplace/appMarketPlaceDefinition.py +5 -1
  314. metadata/generated/schema/entity/applications/marketplace/createAppMarketPlaceDefinitionReq.py +1 -1
  315. metadata/generated/schema/entity/applications/scheduledExecutionContext.py +1 -1
  316. metadata/generated/schema/entity/automations/__init__.py +1 -1
  317. metadata/generated/schema/entity/automations/testServiceConnection.py +1 -1
  318. metadata/generated/schema/entity/automations/workflow.py +1 -1
  319. metadata/generated/schema/entity/bot.py +1 -1
  320. metadata/generated/schema/entity/classification/__init__.py +1 -1
  321. metadata/generated/schema/entity/classification/classification.py +2 -3
  322. metadata/generated/schema/entity/classification/tag.py +3 -9
  323. metadata/generated/schema/entity/data/__init__.py +1 -1
  324. metadata/generated/schema/entity/data/chart.py +1 -1
  325. metadata/generated/schema/entity/data/container.py +4 -1
  326. metadata/generated/schema/entity/data/dashboard.py +1 -1
  327. metadata/generated/schema/entity/data/dashboardDataModel.py +2 -2
  328. metadata/generated/schema/entity/data/database.py +1 -1
  329. metadata/generated/schema/entity/data/databaseSchema.py +1 -1
  330. metadata/generated/schema/entity/data/glossary.py +1 -1
  331. metadata/generated/schema/entity/data/glossaryTerm.py +4 -1
  332. metadata/generated/schema/entity/data/metrics.py +1 -1
  333. metadata/generated/schema/entity/data/mlmodel.py +2 -2
  334. metadata/generated/schema/entity/data/pipeline.py +1 -1
  335. metadata/generated/schema/entity/data/query.py +1 -1
  336. metadata/generated/schema/entity/data/report.py +1 -1
  337. metadata/generated/schema/entity/data/searchIndex.py +1 -1
  338. metadata/generated/schema/entity/data/storedProcedure.py +1 -1
  339. metadata/generated/schema/entity/data/table.py +21 -20
  340. metadata/generated/schema/entity/data/topic.py +1 -1
  341. metadata/generated/schema/entity/docStore/__init__.py +1 -1
  342. metadata/generated/schema/entity/docStore/document.py +1 -1
  343. metadata/generated/schema/entity/domains/__init__.py +1 -1
  344. metadata/generated/schema/entity/domains/dataProduct.py +1 -1
  345. metadata/generated/schema/entity/domains/domain.py +1 -1
  346. metadata/generated/schema/entity/events/__init__.py +1 -1
  347. metadata/generated/schema/entity/events/webhook.py +1 -1
  348. metadata/generated/schema/entity/feed/__init__.py +1 -1
  349. metadata/generated/schema/entity/feed/assets.py +18 -0
  350. metadata/generated/schema/entity/feed/customProperty.py +17 -0
  351. metadata/generated/schema/entity/feed/description.py +24 -0
  352. metadata/generated/schema/entity/feed/domain.py +23 -0
  353. metadata/generated/schema/entity/feed/entityInfo.py +19 -0
  354. metadata/generated/schema/entity/feed/owner.py +23 -0
  355. metadata/generated/schema/entity/feed/suggestion.py +1 -1
  356. metadata/generated/schema/entity/feed/tag.py +23 -0
  357. metadata/generated/schema/entity/feed/testCaseResult.py +23 -0
  358. metadata/generated/schema/entity/feed/thread.py +71 -2
  359. metadata/generated/schema/entity/policies/__init__.py +1 -1
  360. metadata/generated/schema/entity/policies/accessControl/__init__.py +1 -1
  361. metadata/generated/schema/entity/policies/accessControl/resourceDescriptor.py +3 -1
  362. metadata/generated/schema/entity/policies/accessControl/resourcePermission.py +1 -1
  363. metadata/generated/schema/entity/policies/accessControl/rule.py +1 -1
  364. metadata/generated/schema/entity/policies/filters.py +3 -3
  365. metadata/generated/schema/entity/policies/policy.py +1 -1
  366. metadata/generated/schema/entity/services/__init__.py +1 -1
  367. metadata/generated/schema/entity/services/connections/__init__.py +1 -1
  368. metadata/generated/schema/entity/services/connections/common/__init__.py +1 -1
  369. metadata/generated/schema/entity/services/connections/common/sslCertPaths.py +1 -1
  370. metadata/generated/schema/entity/services/connections/common/sslCertValues.py +1 -1
  371. metadata/generated/schema/entity/services/connections/common/sslConfig.py +1 -1
  372. metadata/generated/schema/entity/services/connections/connectionBasicType.py +1 -1
  373. metadata/generated/schema/entity/services/connections/dashboard/__init__.py +1 -1
  374. metadata/generated/schema/entity/services/connections/dashboard/customDashboardConnection.py +1 -1
  375. metadata/generated/schema/entity/services/connections/dashboard/domoDashboardConnection.py +1 -1
  376. metadata/generated/schema/entity/services/connections/dashboard/lightdashConnection.py +1 -1
  377. metadata/generated/schema/entity/services/connections/dashboard/lookerConnection.py +1 -1
  378. metadata/generated/schema/entity/services/connections/dashboard/metabaseConnection.py +1 -1
  379. metadata/generated/schema/entity/services/connections/dashboard/modeConnection.py +1 -1
  380. metadata/generated/schema/entity/services/connections/dashboard/mstrConnection.py +1 -1
  381. metadata/generated/schema/entity/services/connections/dashboard/powerBIConnection.py +33 -2
  382. metadata/generated/schema/entity/services/connections/dashboard/powerbi/__init__.py +3 -0
  383. metadata/generated/schema/entity/services/connections/dashboard/powerbi/azureConfig.py +37 -0
  384. metadata/generated/schema/entity/services/connections/dashboard/powerbi/bucketDetails.py +25 -0
  385. metadata/generated/schema/entity/services/connections/dashboard/powerbi/gcsConfig.py +37 -0
  386. metadata/generated/schema/entity/services/connections/dashboard/powerbi/s3Config.py +37 -0
  387. metadata/generated/schema/entity/services/connections/dashboard/qlikCloudConnection.py +38 -0
  388. metadata/generated/schema/entity/services/connections/dashboard/qlikSenseConnection.py +6 -15
  389. metadata/generated/schema/entity/services/connections/dashboard/quickSightConnection.py +1 -1
  390. metadata/generated/schema/entity/services/connections/dashboard/redashConnection.py +1 -1
  391. metadata/generated/schema/entity/services/connections/dashboard/supersetConnection.py +1 -1
  392. metadata/generated/schema/entity/services/connections/dashboard/tableauConnection.py +1 -1
  393. metadata/generated/schema/entity/services/connections/database/__init__.py +1 -1
  394. metadata/generated/schema/entity/services/connections/database/athenaConnection.py +1 -1
  395. metadata/generated/schema/entity/services/connections/database/azureSQLConnection.py +1 -1
  396. metadata/generated/schema/entity/services/connections/database/bigQueryConnection.py +1 -1
  397. metadata/generated/schema/entity/services/connections/database/bigTableConnection.py +1 -1
  398. metadata/generated/schema/entity/services/connections/database/clickhouseConnection.py +1 -1
  399. metadata/generated/schema/entity/services/connections/database/common/__init__.py +1 -1
  400. metadata/generated/schema/entity/services/connections/database/common/azureConfig.py +1 -1
  401. metadata/generated/schema/entity/services/connections/database/common/basicAuth.py +1 -1
  402. metadata/generated/schema/entity/services/connections/database/common/iamAuthConfig.py +1 -1
  403. metadata/generated/schema/entity/services/connections/database/common/jwtAuth.py +1 -1
  404. metadata/generated/schema/entity/services/connections/database/couchbaseConnection.py +1 -1
  405. metadata/generated/schema/entity/services/connections/database/customDatabaseConnection.py +1 -1
  406. metadata/generated/schema/entity/services/connections/database/databricksConnection.py +1 -1
  407. metadata/generated/schema/entity/services/connections/database/datalake/__init__.py +1 -1
  408. metadata/generated/schema/entity/services/connections/database/datalake/azureConfig.py +1 -1
  409. metadata/generated/schema/entity/services/connections/database/datalake/gcsConfig.py +1 -1
  410. metadata/generated/schema/entity/services/connections/database/datalake/s3Config.py +1 -1
  411. metadata/generated/schema/entity/services/connections/database/datalakeConnection.py +1 -1
  412. metadata/generated/schema/entity/services/connections/database/db2Connection.py +1 -1
  413. metadata/generated/schema/entity/services/connections/database/deltaLakeConnection.py +1 -1
  414. metadata/generated/schema/entity/services/connections/database/domoDatabaseConnection.py +1 -1
  415. metadata/generated/schema/entity/services/connections/database/dorisConnection.py +4 -13
  416. metadata/generated/schema/entity/services/connections/database/druidConnection.py +1 -1
  417. metadata/generated/schema/entity/services/connections/database/dynamoDBConnection.py +4 -1
  418. metadata/generated/schema/entity/services/connections/database/glueConnection.py +1 -1
  419. metadata/generated/schema/entity/services/connections/database/greenplumConnection.py +2 -15
  420. metadata/generated/schema/entity/services/connections/database/hiveConnection.py +1 -1
  421. metadata/generated/schema/entity/services/connections/database/iceberg/__init__.py +1 -1
  422. metadata/generated/schema/entity/services/connections/database/iceberg/dynamoDbCatalogConnection.py +1 -1
  423. metadata/generated/schema/entity/services/connections/database/iceberg/glueCatalogConnection.py +1 -1
  424. metadata/generated/schema/entity/services/connections/database/iceberg/hiveCatalogConnection.py +1 -1
  425. metadata/generated/schema/entity/services/connections/database/iceberg/icebergCatalog.py +1 -1
  426. metadata/generated/schema/entity/services/connections/database/iceberg/icebergFileSystem.py +1 -1
  427. metadata/generated/schema/entity/services/connections/database/iceberg/restCatalogConnection.py +1 -1
  428. metadata/generated/schema/entity/services/connections/database/icebergConnection.py +1 -1
  429. metadata/generated/schema/entity/services/connections/database/impalaConnection.py +1 -1
  430. metadata/generated/schema/entity/services/connections/database/mariaDBConnection.py +1 -1
  431. metadata/generated/schema/entity/services/connections/database/mongoDBConnection.py +4 -1
  432. metadata/generated/schema/entity/services/connections/database/mssqlConnection.py +1 -1
  433. metadata/generated/schema/entity/services/connections/database/mysqlConnection.py +4 -13
  434. metadata/generated/schema/entity/services/connections/database/oracleConnection.py +1 -1
  435. metadata/generated/schema/entity/services/connections/database/pinotDBConnection.py +1 -1
  436. metadata/generated/schema/entity/services/connections/database/postgresConnection.py +2 -15
  437. metadata/generated/schema/entity/services/connections/database/prestoConnection.py +11 -1
  438. metadata/generated/schema/entity/services/connections/database/redshiftConnection.py +2 -15
  439. metadata/generated/schema/entity/services/connections/database/salesforceConnection.py +1 -1
  440. metadata/generated/schema/entity/services/connections/database/sapHana/__init__.py +1 -1
  441. metadata/generated/schema/entity/services/connections/database/sapHana/sapHanaHDBConnection.py +1 -1
  442. metadata/generated/schema/entity/services/connections/database/sapHana/sapHanaSQLConnection.py +1 -1
  443. metadata/generated/schema/entity/services/connections/database/sapHanaConnection.py +1 -1
  444. metadata/generated/schema/entity/services/connections/database/sasConnection.py +1 -1
  445. metadata/generated/schema/entity/services/connections/database/singleStoreConnection.py +1 -1
  446. metadata/generated/schema/entity/services/connections/database/snowflakeConnection.py +1 -1
  447. metadata/generated/schema/entity/services/connections/database/sqliteConnection.py +1 -1
  448. metadata/generated/schema/entity/services/connections/database/trinoConnection.py +6 -1
  449. metadata/generated/schema/entity/services/connections/database/unityCatalogConnection.py +1 -1
  450. metadata/generated/schema/entity/services/connections/database/verticaConnection.py +1 -1
  451. metadata/generated/schema/entity/services/connections/messaging/__init__.py +1 -1
  452. metadata/generated/schema/entity/services/connections/messaging/customMessagingConnection.py +1 -1
  453. metadata/generated/schema/entity/services/connections/messaging/kafkaConnection.py +7 -1
  454. metadata/generated/schema/entity/services/connections/messaging/kinesisConnection.py +1 -1
  455. metadata/generated/schema/entity/services/connections/messaging/pulsarConnection.py +1 -1
  456. metadata/generated/schema/entity/services/connections/messaging/redpandaConnection.py +1 -1
  457. metadata/generated/schema/entity/services/connections/messaging/saslMechanismType.py +1 -1
  458. metadata/generated/schema/entity/services/connections/metadata/__init__.py +1 -1
  459. metadata/generated/schema/entity/services/connections/metadata/alationConnection.py +7 -3
  460. metadata/generated/schema/entity/services/connections/metadata/amundsenConnection.py +1 -1
  461. metadata/generated/schema/entity/services/connections/metadata/atlasConnection.py +1 -1
  462. metadata/generated/schema/entity/services/connections/metadata/metadataESConnection.py +1 -1
  463. metadata/generated/schema/entity/services/connections/metadata/openMetadataConnection.py +1 -1
  464. metadata/generated/schema/entity/services/connections/mlmodel/__init__.py +1 -1
  465. metadata/generated/schema/entity/services/connections/mlmodel/customMlModelConnection.py +1 -1
  466. metadata/generated/schema/entity/services/connections/mlmodel/mlflowConnection.py +1 -1
  467. metadata/generated/schema/entity/services/connections/mlmodel/sageMakerConnection.py +1 -1
  468. metadata/generated/schema/entity/services/connections/mlmodel/sklearnConnection.py +1 -1
  469. metadata/generated/schema/entity/services/connections/pipeline/__init__.py +1 -1
  470. metadata/generated/schema/entity/services/connections/pipeline/airbyteConnection.py +1 -1
  471. metadata/generated/schema/entity/services/connections/pipeline/airflowConnection.py +1 -1
  472. metadata/generated/schema/entity/services/connections/pipeline/backendConnection.py +1 -1
  473. metadata/generated/schema/entity/services/connections/pipeline/customPipelineConnection.py +1 -1
  474. metadata/generated/schema/entity/services/connections/pipeline/dagsterConnection.py +1 -1
  475. metadata/generated/schema/entity/services/connections/pipeline/databricksPipelineConnection.py +1 -1
  476. metadata/generated/schema/entity/services/connections/pipeline/domoPipelineConnection.py +1 -1
  477. metadata/generated/schema/entity/services/connections/pipeline/fivetranConnection.py +1 -1
  478. metadata/generated/schema/entity/services/connections/pipeline/gluePipelineConnection.py +1 -1
  479. metadata/generated/schema/entity/services/connections/pipeline/kafkaConnectConnection.py +61 -0
  480. metadata/generated/schema/entity/services/connections/pipeline/nifiConnection.py +1 -1
  481. metadata/generated/schema/entity/services/connections/pipeline/openLineageConnection.py +73 -0
  482. metadata/generated/schema/entity/services/connections/pipeline/sparkConnection.py +1 -1
  483. metadata/generated/schema/entity/services/connections/pipeline/splineConnection.py +1 -1
  484. metadata/generated/schema/entity/services/connections/search/__init__.py +1 -1
  485. metadata/generated/schema/entity/services/connections/search/customSearchConnection.py +1 -1
  486. metadata/generated/schema/entity/services/connections/search/elasticSearch/__init__.py +1 -1
  487. metadata/generated/schema/entity/services/connections/search/elasticSearch/apiAuth.py +1 -1
  488. metadata/generated/schema/entity/services/connections/search/elasticSearch/basicAuth.py +1 -1
  489. metadata/generated/schema/entity/services/connections/search/elasticSearchConnection.py +1 -1
  490. metadata/generated/schema/entity/services/connections/search/openSearchConnection.py +1 -1
  491. metadata/generated/schema/entity/services/connections/serviceConnection.py +1 -1
  492. metadata/generated/schema/entity/services/connections/storage/__init__.py +1 -1
  493. metadata/generated/schema/entity/services/connections/storage/adlsConnection.py +1 -1
  494. metadata/generated/schema/entity/services/connections/storage/customStorageConnection.py +1 -1
  495. metadata/generated/schema/entity/services/connections/storage/gcsConnection.py +1 -1
  496. metadata/generated/schema/entity/services/connections/storage/s3Connection.py +1 -1
  497. metadata/generated/schema/entity/services/connections/testConnectionDefinition.py +1 -1
  498. metadata/generated/schema/entity/services/connections/testConnectionResult.py +1 -1
  499. metadata/generated/schema/entity/services/dashboardService.py +4 -1
  500. metadata/generated/schema/entity/services/databaseService.py +1 -1
  501. metadata/generated/schema/entity/services/ingestionPipelines/__init__.py +1 -1
  502. metadata/generated/schema/entity/services/ingestionPipelines/ingestionPipeline.py +1 -1
  503. metadata/generated/schema/entity/services/ingestionPipelines/pipelineServiceClientResponse.py +1 -1
  504. metadata/generated/schema/entity/services/ingestionPipelines/status.py +1 -1
  505. metadata/generated/schema/entity/services/messagingService.py +1 -1
  506. metadata/generated/schema/entity/services/metadataService.py +1 -1
  507. metadata/generated/schema/entity/services/mlmodelService.py +1 -1
  508. metadata/generated/schema/entity/services/pipelineService.py +7 -1
  509. metadata/generated/schema/entity/services/searchService.py +1 -1
  510. metadata/generated/schema/entity/services/serviceType.py +1 -1
  511. metadata/generated/schema/entity/services/storageService.py +1 -1
  512. metadata/generated/schema/entity/teams/__init__.py +1 -1
  513. metadata/generated/schema/entity/teams/persona.py +1 -1
  514. metadata/generated/schema/entity/teams/role.py +1 -1
  515. metadata/generated/schema/entity/teams/team.py +1 -1
  516. metadata/generated/schema/entity/teams/teamHierarchy.py +1 -1
  517. metadata/generated/schema/entity/teams/user.py +1 -1
  518. metadata/generated/schema/entity/type.py +1 -1
  519. metadata/generated/schema/entity/utils/__init__.py +1 -1
  520. metadata/generated/schema/entity/utils/entitiesCount.py +1 -1
  521. metadata/generated/schema/entity/utils/servicesCount.py +1 -1
  522. metadata/generated/schema/entity/utils/supersetApiConnection.py +1 -1
  523. metadata/generated/schema/events/__init__.py +1 -1
  524. metadata/generated/schema/events/alertMetrics.py +1 -1
  525. metadata/generated/schema/events/api/__init__.py +1 -1
  526. metadata/generated/schema/events/api/createEventSubscription.py +1 -1
  527. metadata/generated/schema/events/emailAlertConfig.py +1 -1
  528. metadata/generated/schema/events/eventFilterRule.py +10 -1
  529. metadata/generated/schema/events/eventSubscription.py +6 -2
  530. metadata/generated/schema/events/eventSubscriptionOffset.py +1 -1
  531. metadata/generated/schema/events/failedEvent.py +1 -1
  532. metadata/generated/schema/events/filterResourceDescriptor.py +1 -1
  533. metadata/generated/schema/events/subscriptionResourceDescriptor.py +1 -1
  534. metadata/generated/schema/metadataIngestion/__init__.py +1 -1
  535. metadata/generated/schema/metadataIngestion/application.py +1 -1
  536. metadata/generated/schema/metadataIngestion/applicationPipeline.py +1 -1
  537. metadata/generated/schema/metadataIngestion/dashboardServiceMetadataPipeline.py +19 -6
  538. metadata/generated/schema/metadataIngestion/dataInsightPipeline.py +1 -1
  539. metadata/generated/schema/metadataIngestion/databaseServiceMetadataPipeline.py +32 -1
  540. metadata/generated/schema/metadataIngestion/databaseServiceProfilerPipeline.py +23 -23
  541. metadata/generated/schema/metadataIngestion/databaseServiceQueryLineagePipeline.py +1 -1
  542. metadata/generated/schema/metadataIngestion/databaseServiceQueryUsagePipeline.py +1 -1
  543. metadata/generated/schema/metadataIngestion/dbtPipeline.py +1 -1
  544. metadata/generated/schema/metadataIngestion/dbtconfig/__init__.py +1 -1
  545. metadata/generated/schema/metadataIngestion/dbtconfig/dbtAzureConfig.py +1 -1
  546. metadata/generated/schema/metadataIngestion/dbtconfig/dbtBucketDetails.py +1 -1
  547. metadata/generated/schema/metadataIngestion/dbtconfig/dbtCloudConfig.py +1 -1
  548. metadata/generated/schema/metadataIngestion/dbtconfig/dbtGCSConfig.py +1 -1
  549. metadata/generated/schema/metadataIngestion/dbtconfig/dbtHttpConfig.py +1 -1
  550. metadata/generated/schema/metadataIngestion/dbtconfig/dbtLocalConfig.py +1 -1
  551. metadata/generated/schema/metadataIngestion/dbtconfig/dbtS3Config.py +1 -1
  552. metadata/generated/schema/metadataIngestion/messagingServiceMetadataPipeline.py +1 -1
  553. metadata/generated/schema/metadataIngestion/metadataToElasticSearchPipeline.py +1 -1
  554. metadata/generated/schema/metadataIngestion/mlmodelServiceMetadataPipeline.py +1 -1
  555. metadata/generated/schema/metadataIngestion/pipelineServiceMetadataPipeline.py +22 -4
  556. metadata/generated/schema/metadataIngestion/searchServiceMetadataPipeline.py +1 -1
  557. metadata/generated/schema/metadataIngestion/storage/__init__.py +1 -1
  558. metadata/generated/schema/metadataIngestion/storage/containerMetadataConfig.py +1 -1
  559. metadata/generated/schema/metadataIngestion/storage/manifestMetadataConfig.py +1 -1
  560. metadata/generated/schema/metadataIngestion/storage/storageBucketDetails.py +1 -1
  561. metadata/generated/schema/metadataIngestion/storage/storageMetadataADLSConfig.py +1 -1
  562. metadata/generated/schema/metadataIngestion/storage/storageMetadataGCSConfig.py +1 -1
  563. metadata/generated/schema/metadataIngestion/storage/storageMetadataHttpConfig.py +1 -1
  564. metadata/generated/schema/metadataIngestion/storage/storageMetadataLocalConfig.py +1 -1
  565. metadata/generated/schema/metadataIngestion/storage/storageMetadataS3Config.py +1 -1
  566. metadata/generated/schema/metadataIngestion/storageServiceMetadataPipeline.py +1 -1
  567. metadata/generated/schema/metadataIngestion/testSuitePipeline.py +1 -1
  568. metadata/generated/schema/metadataIngestion/workflow.py +1 -1
  569. metadata/generated/schema/monitoring/__init__.py +1 -1
  570. metadata/generated/schema/monitoring/eventMonitorProvider.py +1 -1
  571. metadata/generated/schema/security/__init__.py +1 -1
  572. metadata/generated/schema/security/client/__init__.py +1 -1
  573. metadata/generated/schema/security/client/auth0SSOClientConfig.py +1 -1
  574. metadata/generated/schema/security/client/azureSSOClientConfig.py +1 -1
  575. metadata/generated/schema/security/client/customOidcSSOClientConfig.py +1 -1
  576. metadata/generated/schema/security/client/googleSSOClientConfig.py +1 -1
  577. metadata/generated/schema/security/client/oidcClientConfig.py +1 -1
  578. metadata/generated/schema/security/client/oktaSSOClientConfig.py +1 -1
  579. metadata/generated/schema/security/client/openMetadataJWTClientConfig.py +1 -1
  580. metadata/generated/schema/security/client/samlSSOClientConfig.py +1 -1
  581. metadata/generated/schema/security/credentials/__init__.py +1 -1
  582. metadata/generated/schema/security/credentials/accessTokenAuth.py +1 -1
  583. metadata/generated/schema/security/credentials/apiAccessTokenAuth.py +1 -1
  584. metadata/generated/schema/security/credentials/awsCredentials.py +1 -1
  585. metadata/generated/schema/security/credentials/azureCredentials.py +1 -1
  586. metadata/generated/schema/security/credentials/basicAuth.py +1 -1
  587. metadata/generated/schema/security/credentials/bitbucketCredentials.py +1 -1
  588. metadata/generated/schema/security/credentials/gcpCredentials.py +1 -1
  589. metadata/generated/schema/security/credentials/gcpExternalAccount.py +1 -1
  590. metadata/generated/schema/security/credentials/gcpValues.py +1 -1
  591. metadata/generated/schema/security/credentials/gitCredentials.py +1 -1
  592. metadata/generated/schema/security/credentials/githubCredentials.py +1 -1
  593. metadata/generated/schema/security/secrets/__init__.py +1 -1
  594. metadata/generated/schema/security/secrets/secretsManagerClientLoader.py +1 -1
  595. metadata/generated/schema/security/secrets/secretsManagerConfiguration.py +1 -1
  596. metadata/generated/schema/security/secrets/secretsManagerProvider.py +1 -1
  597. metadata/generated/schema/security/securityConfiguration.py +1 -1
  598. metadata/generated/schema/security/ssl/__init__.py +1 -1
  599. metadata/generated/schema/security/ssl/validateSSLClientConfig.py +16 -4
  600. metadata/generated/schema/security/ssl/verifySSLConfig.py +10 -1
  601. metadata/generated/schema/settings/__init__.py +1 -1
  602. metadata/generated/schema/settings/settings.py +5 -2
  603. metadata/generated/schema/system/__init__.py +1 -1
  604. metadata/generated/schema/system/entityError.py +1 -1
  605. metadata/generated/schema/system/eventPublisherJob.py +1 -1
  606. metadata/generated/schema/system/indexingError.py +1 -1
  607. metadata/generated/schema/system/ui/__init__.py +1 -1
  608. metadata/generated/schema/system/ui/knowledgePanel.py +1 -1
  609. metadata/generated/schema/system/ui/page.py +1 -1
  610. metadata/generated/schema/system/validationResponse.py +1 -1
  611. metadata/generated/schema/tests/__init__.py +1 -1
  612. metadata/generated/schema/tests/assigned.py +1 -1
  613. metadata/generated/schema/tests/basic.py +31 -15
  614. metadata/generated/schema/tests/customMetric.py +1 -1
  615. metadata/generated/schema/tests/resolved.py +1 -1
  616. metadata/generated/schema/tests/testCase.py +12 -1
  617. metadata/generated/schema/tests/testCaseResolutionStatus.py +1 -1
  618. metadata/generated/schema/tests/testDefinition.py +21 -1
  619. metadata/generated/schema/tests/testSuite.py +1 -1
  620. metadata/generated/schema/type/__init__.py +1 -1
  621. metadata/generated/schema/type/auditLog.py +1 -1
  622. metadata/generated/schema/type/basic.py +1 -1
  623. metadata/generated/schema/type/bulkOperationResult.py +1 -1
  624. metadata/generated/schema/type/changeEvent.py +1 -1
  625. metadata/generated/schema/type/changeEventType.py +1 -1
  626. metadata/generated/schema/type/collectionDescriptor.py +1 -1
  627. metadata/generated/schema/type/csvDocumentation.py +1 -1
  628. metadata/generated/schema/type/csvErrorType.py +1 -1
  629. metadata/generated/schema/type/csvFile.py +1 -1
  630. metadata/generated/schema/type/csvImportResult.py +1 -1
  631. metadata/generated/schema/type/customProperties/__init__.py +1 -1
  632. metadata/generated/schema/type/customProperties/complexTypes.py +87 -0
  633. metadata/generated/schema/type/customProperties/enumConfig.py +1 -1
  634. metadata/generated/schema/type/customProperty.py +3 -3
  635. metadata/generated/schema/type/dailyCount.py +1 -1
  636. metadata/generated/schema/type/databaseConnectionConfig.py +1 -1
  637. metadata/generated/schema/type/entityHierarchy.py +39 -0
  638. metadata/generated/schema/type/entityHistory.py +1 -1
  639. metadata/generated/schema/type/entityLineage.py +3 -1
  640. metadata/generated/schema/type/entityReference.py +1 -1
  641. metadata/generated/schema/type/entityReferenceList.py +1 -1
  642. metadata/generated/schema/type/entityRelationship.py +1 -1
  643. metadata/generated/schema/type/entityUsage.py +1 -1
  644. metadata/generated/schema/type/filterPattern.py +1 -1
  645. metadata/generated/schema/type/function.py +1 -1
  646. metadata/generated/schema/type/include.py +1 -1
  647. metadata/generated/schema/type/jdbcConnection.py +1 -1
  648. metadata/generated/schema/type/lifeCycle.py +1 -1
  649. metadata/generated/schema/type/paging.py +4 -1
  650. metadata/generated/schema/type/profile.py +1 -1
  651. metadata/generated/schema/type/queryParserData.py +1 -1
  652. metadata/generated/schema/type/reaction.py +1 -1
  653. metadata/generated/schema/type/schedule.py +1 -1
  654. metadata/generated/schema/type/schema.py +1 -1
  655. metadata/generated/schema/type/tableQuery.py +1 -1
  656. metadata/generated/schema/type/tableUsageCount.py +1 -1
  657. metadata/generated/schema/type/tagLabel.py +1 -1
  658. metadata/generated/schema/type/usageDetails.py +1 -1
  659. metadata/generated/schema/type/usageRequest.py +1 -1
  660. metadata/generated/schema/type/votes.py +1 -1
  661. metadata/great_expectations/action.py +0 -1
  662. metadata/ingestion/api/delete.py +33 -1
  663. metadata/ingestion/api/step.py +6 -1
  664. metadata/ingestion/api/topology_runner.py +122 -25
  665. metadata/ingestion/bulksink/metadata_usage.py +6 -1
  666. metadata/ingestion/lineage/models.py +34 -1
  667. metadata/ingestion/lineage/parser.py +15 -8
  668. metadata/ingestion/lineage/sql_lineage.py +21 -3
  669. metadata/ingestion/models/custom_properties.py +1 -0
  670. metadata/ingestion/models/life_cycle.py +4 -1
  671. metadata/ingestion/models/patch_request.py +176 -34
  672. metadata/ingestion/models/topology.py +81 -1
  673. metadata/ingestion/ometa/client.py +3 -0
  674. metadata/ingestion/ometa/mixins/es_mixin.py +95 -42
  675. metadata/ingestion/ometa/mixins/lineage_mixin.py +169 -4
  676. metadata/ingestion/ometa/mixins/patch_mixin.py +5 -2
  677. metadata/ingestion/ometa/mixins/server_mixin.py +48 -0
  678. metadata/ingestion/ometa/mixins/tests_mixin.py +55 -1
  679. metadata/ingestion/ometa/mixins/user_mixin.py +2 -2
  680. metadata/ingestion/ometa/ometa_api.py +6 -1
  681. metadata/ingestion/ometa/routes.py +3 -0
  682. metadata/ingestion/ometa/utils.py +2 -0
  683. metadata/ingestion/processor/query_parser.py +7 -1
  684. metadata/ingestion/sink/file.py +4 -1
  685. metadata/ingestion/sink/metadata_rest.py +19 -5
  686. metadata/ingestion/source/dashboard/dashboard_service.py +75 -16
  687. metadata/ingestion/source/dashboard/domodashboard/metadata.py +7 -5
  688. metadata/ingestion/source/dashboard/lightdash/metadata.py +7 -5
  689. metadata/ingestion/source/dashboard/looker/metadata.py +25 -18
  690. metadata/ingestion/source/dashboard/metabase/client.py +39 -8
  691. metadata/ingestion/source/dashboard/metabase/connection.py +2 -1
  692. metadata/ingestion/source/dashboard/metabase/metadata.py +9 -7
  693. metadata/ingestion/source/dashboard/metabase/models.py +1 -1
  694. metadata/ingestion/source/dashboard/mode/metadata.py +7 -5
  695. metadata/ingestion/source/dashboard/mstr/metadata.py +10 -5
  696. metadata/ingestion/source/dashboard/powerbi/client.py +13 -3
  697. metadata/ingestion/source/dashboard/powerbi/connection.py +13 -5
  698. metadata/ingestion/source/dashboard/powerbi/file_client.py +327 -0
  699. metadata/ingestion/source/dashboard/powerbi/metadata.py +130 -52
  700. metadata/ingestion/source/dashboard/powerbi/models.py +26 -0
  701. metadata/ingestion/source/dashboard/qlikcloud/__init__.py +0 -0
  702. metadata/ingestion/source/dashboard/qlikcloud/client.py +167 -0
  703. metadata/ingestion/source/dashboard/qlikcloud/connection.py +56 -0
  704. metadata/ingestion/source/dashboard/qlikcloud/constants.py +66 -0
  705. metadata/ingestion/source/dashboard/qlikcloud/metadata.py +249 -0
  706. metadata/ingestion/source/dashboard/qlikcloud/models.py +33 -0
  707. metadata/ingestion/source/dashboard/qliksense/client.py +9 -26
  708. metadata/ingestion/source/dashboard/qliksense/metadata.py +30 -17
  709. metadata/ingestion/source/dashboard/qliksense/models.py +1 -0
  710. metadata/ingestion/source/dashboard/quicksight/metadata.py +7 -5
  711. metadata/ingestion/source/dashboard/redash/metadata.py +10 -5
  712. metadata/ingestion/source/dashboard/superset/api_source.py +10 -5
  713. metadata/ingestion/source/dashboard/superset/db_source.py +12 -6
  714. metadata/ingestion/source/dashboard/superset/metadata.py +8 -1
  715. metadata/ingestion/source/dashboard/superset/mixin.py +20 -3
  716. metadata/ingestion/source/dashboard/superset/models.py +2 -0
  717. metadata/ingestion/source/dashboard/superset/queries.py +23 -6
  718. metadata/ingestion/source/dashboard/tableau/metadata.py +71 -10
  719. metadata/ingestion/source/database/athena/metadata.py +83 -15
  720. metadata/ingestion/source/database/athena/query_parser.py +4 -1
  721. metadata/ingestion/source/database/azuresql/metadata.py +4 -2
  722. metadata/ingestion/source/database/azuresql/query_parser.py +4 -1
  723. metadata/ingestion/source/database/bigquery/helper.py +23 -12
  724. metadata/ingestion/source/database/bigquery/incremental_table_processor.py +86 -0
  725. metadata/ingestion/source/database/bigquery/metadata.py +196 -43
  726. metadata/ingestion/source/database/bigquery/models.py +35 -1
  727. metadata/ingestion/source/database/bigquery/queries.py +25 -12
  728. metadata/ingestion/source/database/bigquery/query_parser.py +3 -1
  729. metadata/ingestion/source/database/bigtable/metadata.py +6 -4
  730. metadata/ingestion/source/database/clickhouse/metadata.py +3 -1
  731. metadata/ingestion/source/database/clickhouse/query_parser.py +4 -2
  732. metadata/ingestion/source/database/common_db_source.py +92 -46
  733. metadata/ingestion/source/database/common_nosql_source.py +15 -15
  734. metadata/ingestion/source/database/couchbase/metadata.py +8 -6
  735. metadata/ingestion/source/database/database_service.py +40 -26
  736. metadata/ingestion/source/database/databricks/metadata.py +71 -19
  737. metadata/ingestion/source/database/databricks/queries.py +3 -1
  738. metadata/ingestion/source/database/databricks/query_parser.py +9 -2
  739. metadata/ingestion/source/database/datalake/connection.py +1 -2
  740. metadata/ingestion/source/database/datalake/metadata.py +21 -19
  741. metadata/ingestion/source/database/db2/metadata.py +4 -1
  742. metadata/ingestion/source/database/dbt/dbt_service.py +13 -11
  743. metadata/ingestion/source/database/dbt/metadata.py +89 -19
  744. metadata/ingestion/source/database/dbt/models.py +10 -1
  745. metadata/ingestion/source/database/deltalake/metadata.py +18 -16
  746. metadata/ingestion/source/database/domodatabase/metadata.py +16 -11
  747. metadata/ingestion/source/database/doris/connection.py +0 -10
  748. metadata/ingestion/source/database/doris/metadata.py +23 -4
  749. metadata/ingestion/source/database/druid/metadata.py +5 -1
  750. metadata/ingestion/source/database/dynamodb/metadata.py +3 -1
  751. metadata/ingestion/source/database/extended_sample_data.py +4 -2
  752. metadata/ingestion/source/database/external_table_lineage_mixin.py +82 -0
  753. metadata/ingestion/source/database/glue/metadata.py +23 -21
  754. metadata/ingestion/source/database/greenplum/connection.py +0 -10
  755. metadata/ingestion/source/database/greenplum/metadata.py +26 -11
  756. metadata/ingestion/source/database/hive/metadata.py +6 -4
  757. metadata/ingestion/source/database/iceberg/helper.py +42 -5
  758. metadata/ingestion/source/database/iceberg/metadata.py +18 -16
  759. metadata/ingestion/source/database/iceberg/models.py +12 -4
  760. metadata/ingestion/source/database/impala/metadata.py +4 -1
  761. metadata/ingestion/source/database/incremental_metadata_extraction.py +144 -0
  762. metadata/ingestion/source/database/life_cycle_query_mixin.py +39 -36
  763. metadata/ingestion/source/database/mariadb/metadata.py +5 -1
  764. metadata/ingestion/source/database/mongodb/metadata.py +4 -2
  765. metadata/ingestion/source/database/mssql/metadata.py +9 -7
  766. metadata/ingestion/source/database/mssql/queries.py +18 -16
  767. metadata/ingestion/source/database/mssql/query_parser.py +4 -1
  768. metadata/ingestion/source/database/mssql/utils.py +3 -0
  769. metadata/ingestion/source/database/mysql/connection.py +0 -11
  770. metadata/ingestion/source/database/mysql/metadata.py +4 -2
  771. metadata/ingestion/source/database/oracle/connection.py +2 -2
  772. metadata/ingestion/source/database/oracle/metadata.py +7 -5
  773. metadata/ingestion/source/database/oracle/queries.py +13 -13
  774. metadata/ingestion/source/database/oracle/query_parser.py +4 -1
  775. metadata/ingestion/source/database/pinotdb/metadata.py +4 -1
  776. metadata/ingestion/source/database/postgres/connection.py +0 -10
  777. metadata/ingestion/source/database/postgres/metadata.py +34 -15
  778. metadata/ingestion/source/database/postgres/queries.py +17 -1
  779. metadata/ingestion/source/database/postgres/query_parser.py +4 -2
  780. metadata/ingestion/source/database/postgres/utils.py +98 -0
  781. metadata/ingestion/source/database/presto/connection.py +14 -0
  782. metadata/ingestion/source/database/presto/metadata.py +8 -5
  783. metadata/ingestion/source/database/query/lineage.py +5 -1
  784. metadata/ingestion/source/database/query/usage.py +4 -1
  785. metadata/ingestion/source/database/redshift/connection.py +0 -10
  786. metadata/ingestion/source/database/redshift/incremental_table_processor.py +192 -0
  787. metadata/ingestion/source/database/redshift/metadata.py +167 -25
  788. metadata/ingestion/source/database/redshift/models.py +74 -1
  789. metadata/ingestion/source/database/redshift/queries.py +17 -2
  790. metadata/ingestion/source/database/redshift/query_parser.py +3 -1
  791. metadata/ingestion/source/database/redshift/utils.py +13 -7
  792. metadata/ingestion/source/database/salesforce/metadata.py +13 -11
  793. metadata/ingestion/source/database/sample_data.py +55 -10
  794. metadata/ingestion/source/database/sample_usage.py +3 -1
  795. metadata/ingestion/source/database/saphana/metadata.py +6 -5
  796. metadata/ingestion/source/database/sas/metadata.py +8 -3
  797. metadata/ingestion/source/database/singlestore/metadata.py +5 -1
  798. metadata/ingestion/source/database/snowflake/metadata.py +189 -58
  799. metadata/ingestion/source/database/snowflake/models.py +24 -1
  800. metadata/ingestion/source/database/snowflake/queries.py +143 -25
  801. metadata/ingestion/source/database/snowflake/query_parser.py +3 -1
  802. metadata/ingestion/source/database/snowflake/utils.py +167 -11
  803. metadata/ingestion/source/database/sql_column_handler.py +2 -0
  804. metadata/ingestion/source/database/sqlalchemy_source.py +2 -2
  805. metadata/ingestion/source/database/sqlite/metadata.py +5 -1
  806. metadata/ingestion/source/database/stored_procedures_mixin.py +11 -9
  807. metadata/ingestion/source/database/trino/connection.py +7 -0
  808. metadata/ingestion/source/database/trino/metadata.py +7 -4
  809. metadata/ingestion/source/database/trino/query_parser.py +4 -1
  810. metadata/ingestion/source/database/unitycatalog/lineage.py +3 -1
  811. metadata/ingestion/source/database/unitycatalog/metadata.py +43 -32
  812. metadata/ingestion/source/database/unitycatalog/query_parser.py +4 -1
  813. metadata/ingestion/source/database/vertica/metadata.py +4 -2
  814. metadata/ingestion/source/database/vertica/query_parser.py +4 -2
  815. metadata/ingestion/source/messaging/common_broker_source.py +3 -3
  816. metadata/ingestion/source/messaging/kafka/metadata.py +21 -1
  817. metadata/ingestion/source/messaging/kinesis/metadata.py +11 -5
  818. metadata/ingestion/source/messaging/messaging_service.py +3 -3
  819. metadata/ingestion/source/messaging/redpanda/metadata.py +5 -1
  820. metadata/ingestion/source/metadata/amundsen/metadata.py +3 -1
  821. metadata/ingestion/source/metadata/atlas/metadata.py +3 -1
  822. metadata/ingestion/source/mlmodel/mlflow/metadata.py +4 -2
  823. metadata/ingestion/source/mlmodel/mlmodel_service.py +3 -3
  824. metadata/ingestion/source/mlmodel/sagemaker/metadata.py +8 -3
  825. metadata/ingestion/source/pipeline/airbyte/metadata.py +9 -7
  826. metadata/ingestion/source/pipeline/airflow/metadata.py +30 -14
  827. metadata/ingestion/source/pipeline/dagster/metadata.py +17 -15
  828. metadata/ingestion/source/pipeline/databrickspipeline/metadata.py +10 -8
  829. metadata/ingestion/source/pipeline/domopipeline/metadata.py +6 -4
  830. metadata/ingestion/source/pipeline/fivetran/metadata.py +6 -4
  831. metadata/ingestion/source/pipeline/gluepipeline/metadata.py +7 -5
  832. metadata/ingestion/source/pipeline/nifi/metadata.py +4 -2
  833. metadata/ingestion/source/pipeline/openlineage/__init__.py +0 -0
  834. metadata/ingestion/source/pipeline/openlineage/connection.py +88 -0
  835. metadata/ingestion/source/pipeline/openlineage/metadata.py +520 -0
  836. metadata/ingestion/source/pipeline/openlineage/models.py +88 -0
  837. metadata/ingestion/source/pipeline/openlineage/utils.py +59 -0
  838. metadata/ingestion/source/pipeline/pipeline_service.py +13 -3
  839. metadata/ingestion/source/pipeline/spline/metadata.py +8 -6
  840. metadata/ingestion/source/search/elasticsearch/metadata.py +8 -6
  841. metadata/ingestion/source/search/search_service.py +3 -3
  842. metadata/ingestion/source/sqa_types.py +20 -1
  843. metadata/ingestion/source/storage/s3/metadata.py +33 -7
  844. metadata/ingestion/source/storage/s3/models.py +4 -0
  845. metadata/ingestion/source/storage/storage_service.py +4 -4
  846. metadata/ingestion/stage/table_usage.py +6 -1
  847. metadata/mixins/pandas/pandas_mixin.py +3 -3
  848. metadata/pii/processor.py +6 -1
  849. metadata/profiler/__init__.py +0 -0
  850. metadata/profiler/adaptors/__init__.py +0 -0
  851. metadata/profiler/adaptors/adaptor_factory.py +43 -0
  852. metadata/profiler/adaptors/dynamodb.py +40 -0
  853. metadata/profiler/adaptors/factory.py +76 -0
  854. metadata/profiler/adaptors/mongodb.py +178 -0
  855. metadata/profiler/adaptors/nosql_adaptor.py +65 -0
  856. metadata/profiler/api/models.py +1 -1
  857. metadata/profiler/factory.py +41 -0
  858. metadata/profiler/interface/nosql/profiler_interface.py +236 -0
  859. metadata/profiler/interface/pandas/profiler_interface.py +51 -30
  860. metadata/profiler/interface/profiler_interface.py +6 -2
  861. metadata/profiler/interface/profiler_interface_factory.py +11 -22
  862. metadata/profiler/interface/sqlalchemy/databricks/profiler_interface.py +79 -0
  863. metadata/profiler/interface/sqlalchemy/profiler_interface.py +3 -1
  864. metadata/profiler/interface/sqlalchemy/unity_catalog/profiler_interface.py +3 -6
  865. metadata/profiler/metrics/composed/distinct_ratio.py +2 -1
  866. metadata/profiler/metrics/composed/duplicate_count.py +2 -1
  867. metadata/profiler/metrics/composed/ilike_ratio.py +2 -1
  868. metadata/profiler/metrics/composed/iqr.py +2 -1
  869. metadata/profiler/metrics/composed/like_ratio.py +2 -1
  870. metadata/profiler/metrics/composed/non_parametric_skew.py +2 -1
  871. metadata/profiler/metrics/composed/null_ratio.py +7 -4
  872. metadata/profiler/metrics/composed/unique_ratio.py +2 -1
  873. metadata/profiler/metrics/core.py +14 -1
  874. metadata/profiler/metrics/hybrid/histogram.py +2 -1
  875. metadata/profiler/metrics/registry.py +4 -0
  876. metadata/profiler/metrics/static/column_count.py +2 -1
  877. metadata/profiler/metrics/static/column_names.py +2 -1
  878. metadata/profiler/metrics/static/count.py +2 -1
  879. metadata/profiler/metrics/static/count_in_set.py +2 -1
  880. metadata/profiler/metrics/static/distinct_count.py +11 -2
  881. metadata/profiler/metrics/static/ilike_count.py +2 -1
  882. metadata/profiler/metrics/static/like_count.py +2 -1
  883. metadata/profiler/metrics/static/max.py +26 -7
  884. metadata/profiler/metrics/static/max_length.py +3 -2
  885. metadata/profiler/metrics/static/mean.py +30 -22
  886. metadata/profiler/metrics/static/min.py +25 -6
  887. metadata/profiler/metrics/static/min_length.py +3 -2
  888. metadata/profiler/metrics/static/not_like_count.py +2 -1
  889. metadata/profiler/metrics/static/not_regexp_match_count.py +2 -1
  890. metadata/profiler/metrics/static/null_count.py +2 -1
  891. metadata/profiler/metrics/static/null_missing_count.py +73 -0
  892. metadata/profiler/metrics/static/regexp_match_count.py +2 -1
  893. metadata/profiler/metrics/static/row_count.py +9 -3
  894. metadata/profiler/metrics/static/stddev.py +2 -1
  895. metadata/profiler/metrics/static/sum.py +22 -4
  896. metadata/profiler/metrics/static/unique_count.py +13 -4
  897. metadata/profiler/metrics/system/system.py +2 -1
  898. metadata/profiler/metrics/window/first_quartile.py +2 -1
  899. metadata/profiler/metrics/window/median.py +8 -2
  900. metadata/profiler/metrics/window/third_quartile.py +2 -1
  901. metadata/profiler/orm/converter/base.py +4 -1
  902. metadata/profiler/orm/converter/bigquery/converter.py +11 -0
  903. metadata/profiler/orm/converter/common.py +47 -0
  904. metadata/profiler/orm/converter/converter_registry.py +2 -0
  905. metadata/profiler/orm/converter/redshift/converter.py +48 -0
  906. metadata/profiler/orm/converter/snowflake/converter.py +13 -0
  907. metadata/profiler/orm/functions/conn_test.py +1 -1
  908. metadata/profiler/orm/functions/sum.py +4 -2
  909. metadata/profiler/orm/functions/table_metric_computer.py +39 -20
  910. metadata/profiler/orm/registry.py +6 -3
  911. metadata/profiler/processor/core.py +58 -97
  912. metadata/profiler/processor/default.py +5 -0
  913. metadata/profiler/processor/handle_partition.py +3 -3
  914. metadata/profiler/processor/metric_filter.py +265 -0
  915. metadata/profiler/processor/processor.py +4 -2
  916. metadata/profiler/processor/sampler/nosql/sampler.py +72 -0
  917. metadata/profiler/processor/sampler/pandas/sampler.py +5 -6
  918. metadata/profiler/processor/sampler/sampler_factory.py +9 -0
  919. metadata/profiler/processor/sampler/sampler_interface.py +2 -2
  920. metadata/profiler/processor/sampler/sqlalchemy/sampler.py +3 -3
  921. metadata/profiler/source/base/profiler_source.py +11 -3
  922. metadata/profiler/source/databricks/profiler_source.py +5 -1
  923. metadata/profiler/source/metadata.py +8 -1
  924. metadata/profiler/source/metadata_ext.py +2 -0
  925. metadata/readers/dataframe/avro.py +5 -5
  926. metadata/readers/dataframe/json.py +1 -1
  927. metadata/readers/file/adls.py +20 -0
  928. metadata/readers/file/base.py +6 -0
  929. metadata/readers/file/config_source_factory.py +12 -0
  930. metadata/readers/file/gcs.py +18 -0
  931. metadata/readers/file/local.py +12 -0
  932. metadata/readers/file/s3.py +16 -0
  933. metadata/utils/constants.py +32 -24
  934. metadata/utils/datalake/datalake_utils.py +40 -4
  935. metadata/utils/execution_time_tracker.py +69 -28
  936. metadata/utils/fqn.py +61 -7
  937. metadata/utils/helpers.py +2 -0
  938. metadata/utils/importer.py +15 -6
  939. metadata/utils/logger.py +1 -1
  940. metadata/utils/lru_cache.py +2 -0
  941. metadata/utils/partition.py +93 -28
  942. metadata/utils/sqlalchemy_utils.py +15 -0
  943. metadata/utils/ssl_manager.py +181 -0
  944. metadata/utils/tag_utils.py +30 -13
  945. metadata/utils/test_utils.py +65 -0
  946. metadata/workflow/application.py +6 -1
  947. metadata/workflow/base.py +1 -1
  948. metadata/workflow/ingestion.py +19 -0
  949. metadata/workflow/metadata.py +9 -1
  950. metadata/workflow/output_handler.py +24 -2
  951. metadata/workflow/workflow_output_handler.py +2 -0
  952. {openmetadata_ingestion-1.3.3.0rc1.dist-info → openmetadata_ingestion-1.4.0.0rc1.dist-info}/METADATA +306 -307
  953. {openmetadata_ingestion-1.3.3.0rc1.dist-info → openmetadata_ingestion-1.4.0.0rc1.dist-info}/RECORD +957 -894
  954. metadata/cli/docker.py +0 -382
  955. metadata/cli/openmetadata_dag_config_migration.py +0 -109
  956. metadata/cli/openmetadata_imports_migration.py +0 -71
  957. metadata/generated/schema/entity/applications/configuration/external/autoTaggerAppConfig.py +0 -28
  958. {openmetadata_ingestion-1.3.3.0rc1.dist-info → openmetadata_ingestion-1.4.0.0rc1.dist-info}/LICENSE +0 -0
  959. {openmetadata_ingestion-1.3.3.0rc1.dist-info → openmetadata_ingestion-1.4.0.0rc1.dist-info}/WHEEL +0 -0
  960. {openmetadata_ingestion-1.3.3.0rc1.dist-info → openmetadata_ingestion-1.4.0.0rc1.dist-info}/entry_points.txt +0 -0
  961. {openmetadata_ingestion-1.3.3.0rc1.dist-info → openmetadata_ingestion-1.4.0.0rc1.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,48 @@
1
+ # Copyright 2021 Collate
2
+ # Licensed under the Apache License, Version 2.0 (the "License");
3
+ # you may not use this file except in compliance with the License.
4
+ # You may obtain a copy of the License at
5
+ # http://www.apache.org/licenses/LICENSE-2.0
6
+ # Unless required by applicable law or agreed to in writing, software
7
+ # distributed under the License is distributed on an "AS IS" BASIS,
8
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
+ # See the License for the specific language governing permissions and
10
+ # limitations under the License.
11
+
12
+ """
13
+ Converter logic to transform an OpenMetadata Table Entity for Redshift
14
+ to an SQLAlchemy ORM class.
15
+ """
16
+
17
+ from metadata.generated.schema.entity.data.table import Column, DataType
18
+ from metadata.generated.schema.entity.services import databaseService
19
+ from metadata.profiler.orm.converter.common import CommonMapTypes
20
+
21
+
22
+ class RedshiftMapTypes(CommonMapTypes):
23
+ """Redshift mapper, inherits from CommonMapTypes"""
24
+
25
+ def __init__(self) -> None:
26
+ self._TYPE_MAP.update({DataType.GEOMETRY: DataType.GEOMETRY.value})
27
+
28
+ def return_custom_type(self, col: Column, table_service_type):
29
+ if (
30
+ table_service_type == databaseService.DatabaseServiceType.Redshift
31
+ and col.dataType == DataType.GEOMETRY
32
+ ):
33
+ # pylint: disable=import-outside-toplevel
34
+ from sqlalchemy_redshift.dialect import GEOMETRY
35
+
36
+ return GEOMETRY
37
+ return super().return_custom_type(col, table_service_type)
38
+
39
+ @staticmethod
40
+ def map_sqa_to_om_types() -> dict:
41
+ """returns an ORM type"""
42
+ # pylint: disable=import-outside-toplevel
43
+ from sqlalchemy_redshift.dialect import GEOMETRY
44
+
45
+ return {
46
+ **CommonMapTypes.map_sqa_to_om_types(),
47
+ GEOMETRY: DataType.GEOMETRY,
48
+ }
@@ -22,6 +22,8 @@ from metadata.profiler.orm.registry import CustomTypes
22
22
 
23
23
 
24
24
  class SnowflakeMapTypes(CommonMapTypes):
25
+ """Snowflake mapper, inherits from CommonMapTypes"""
26
+
25
27
  def __init__(self) -> None:
26
28
  self._TYPE_MAP.update({DataType.BINARY: CustomTypes.BYTES.value})
27
29
 
@@ -35,3 +37,14 @@ class SnowflakeMapTypes(CommonMapTypes):
35
37
 
36
38
  return VARIANT
37
39
  return super().return_custom_type(col, table_service_type)
40
+
41
+ @staticmethod
42
+ def map_sqa_to_om_types() -> dict:
43
+ """returns an ORM type"""
44
+ # pylint: disable=import-outside-toplevel
45
+ from snowflake.sqlalchemy import VARIANT
46
+
47
+ return {
48
+ **CommonMapTypes.map_sqa_to_om_types(),
49
+ VARIANT: DataType.JSON,
50
+ }
@@ -50,7 +50,7 @@ def _(*_, **__):
50
50
  @compiles(ConnTestFn, Dialects.IbmDbSa)
51
51
  @compiles(ConnTestFn, Dialects.Ibmi)
52
52
  def _(*_, **__):
53
- return "SELECT 42 FROM SYSIBM.SYSDUMMY1;"
53
+ return "SELECT 42 FROM SYSIBM.SYSDUMMY1"
54
54
 
55
55
 
56
56
  @compiles(ConnTestFn, Dialects.Hana)
@@ -32,11 +32,13 @@ def _(element, compiler, **kw):
32
32
  return f"SUM(CAST({proc} AS BIGINT))"
33
33
 
34
34
 
35
+ @compiles(SumFn, Dialects.Athena)
35
36
  @compiles(SumFn, Dialects.Trino)
37
+ @compiles(SumFn, Dialects.Presto)
36
38
  def _(element, compiler, **kw):
37
- """Cast to BIGINT to address cannot cast nan to bigint"""
39
+ """Cast to DECIMAL to address cannot cast nan to bigint"""
38
40
  proc = compiler.process(element.clauses, **kw)
39
- return f"SUM(TRY_CAST({proc} AS BIGINT))"
41
+ return f"SUM(TRY_CAST({proc} AS DECIMAL))"
40
42
 
41
43
 
42
44
  @compiles(SumFn, Dialects.BigQuery)
@@ -22,6 +22,8 @@ from sqlalchemy import Column, MetaData, Table, func, inspect, literal, select
22
22
  from sqlalchemy.sql.expression import ColumnOperators, and_, cte
23
23
  from sqlalchemy.types import String
24
24
 
25
+ from metadata.generated.schema.entity.data.table import Table as OMTable
26
+ from metadata.generated.schema.entity.data.table import TableType
25
27
  from metadata.profiler.metrics.registry import Metrics
26
28
  from metadata.profiler.orm.registry import Dialects
27
29
  from metadata.profiler.processor.runner import QueryRunner
@@ -31,7 +33,7 @@ logger = profiler_interface_registry_logger()
31
33
 
32
34
  COLUMN_COUNT = "columnCount"
33
35
  COLUMN_NAMES = "columnNames"
34
- ROW_COUNT = "rowCount"
36
+ ROW_COUNT = Metrics.ROW_COUNT().name()
35
37
  SIZE_IN_BYTES = "sizeInBytes"
36
38
  CREATE_DATETIME = "createDateTime"
37
39
 
@@ -43,13 +45,16 @@ ERROR_MSG = (
43
45
  class AbstractTableMetricComputer(ABC):
44
46
  """Base table computer"""
45
47
 
46
- def __init__(self, runner: QueryRunner, metrics: List[Metrics], conn_config):
48
+ def __init__(
49
+ self, runner: QueryRunner, metrics: List[Metrics], conn_config, entity: OMTable
50
+ ):
47
51
  """Instantiate base table computer"""
48
52
  self._runner = runner
49
53
  self._metrics = metrics
50
54
  self._conn_config = conn_config
51
55
  self._database = self._runner._session.get_bind().url.database
52
56
  self._table = self._runner.table
57
+ self._entity = entity
53
58
 
54
59
  @property
55
60
  def database(self):
@@ -141,16 +146,6 @@ class AbstractTableMetricComputer(ABC):
141
146
  class BaseTableMetricComputer(AbstractTableMetricComputer):
142
147
  """Base table computer"""
143
148
 
144
- def _check_and_return(self, res):
145
- """Check if the result is None and return the result or fallback
146
-
147
- Args:
148
- res (object): result
149
- """
150
- if res.rowCount is None:
151
- return super().compute()
152
- return res
153
-
154
149
  def compute(self):
155
150
  """Default compute behavior for table metrics"""
156
151
  return self.runner.select_first_from_table(
@@ -199,7 +194,7 @@ class OracleTableMetricComputer(BaseTableMetricComputer):
199
194
  Column("object_name").label("table_name"),
200
195
  Column("created"),
201
196
  ],
202
- self._build_table("dba_objects", None),
197
+ self._build_table("all_objects", None),
203
198
  [
204
199
  func.lower(Column("owner")) == self.schema_name.lower(),
205
200
  func.lower(Column("object_name")) == self.table_name.lower(),
@@ -236,7 +231,9 @@ class OracleTableMetricComputer(BaseTableMetricComputer):
236
231
  )
237
232
 
238
233
  res = self.runner._session.execute(query).first()
239
- if res.rowCount is None:
234
+ if res.rowCount is None or (
235
+ res.rowCount == 0 and self._entity.tableType == TableType.View
236
+ ):
240
237
  # if we don't have any row count, fallback to the base logic
241
238
  return super().compute()
242
239
  return res
@@ -263,7 +260,9 @@ class ClickHouseTableMetricComputer(BaseTableMetricComputer):
263
260
  )
264
261
 
265
262
  res = self.runner._session.execute(query).first()
266
- if res.rowCount is None:
263
+ if res.rowCount is None or (
264
+ res.rowCount == 0 and self._entity.tableType == TableType.View
265
+ ):
267
266
  # if we don't have any row count, fallback to the base logic
268
267
  return super().compute()
269
268
  return res
@@ -307,7 +306,9 @@ class BigQueryTableMetricComputer(BaseTableMetricComputer):
307
306
  )
308
307
 
309
308
  res = self.runner._session.execute(query).first()
310
- if res.rowCount is None:
309
+ if res.rowCount is None or (
310
+ res.rowCount == 0 and self._entity.tableType == TableType.View
311
+ ):
311
312
  # if we don't have any row count, fallback to the base logic
312
313
  return super().compute()
313
314
  return res
@@ -336,7 +337,9 @@ class BigQueryTableMetricComputer(BaseTableMetricComputer):
336
337
  where_clause,
337
338
  )
338
339
  res = self.runner._session.execute(query).first()
339
- if res.rowCount is None:
340
+ if res.rowCount is None or (
341
+ res.rowCount == 0 and self._entity.tableType == TableType.View
342
+ ):
340
343
  # if we don't have any row count, fallback to the base logic
341
344
  return super().compute()
342
345
  return res
@@ -363,9 +366,16 @@ class MySQLTableMetricComputer(BaseTableMetricComputer):
363
366
  )
364
367
 
365
368
  res = self.runner._session.execute(query).first()
366
- if res.rowCount is None:
369
+ if res.rowCount is None or (
370
+ res.rowCount == 0 and self._entity.tableType == TableType.View
371
+ ):
367
372
  # if we don't have any row count, fallback to the base logic
368
373
  return super().compute()
374
+ res = res._asdict()
375
+ # innodb row count is an estimate we need to patch the row count with COUNT(*)
376
+ # https://dev.mysql.com/doc/refman/8.3/en/information-schema-innodb-tablestats-table.html
377
+ row_count = self.runner.select_first_from_table(Metrics.ROW_COUNT().fn())
378
+ res.update({ROW_COUNT: row_count.rowCount})
369
379
  return res
370
380
 
371
381
 
@@ -390,7 +400,9 @@ class RedshiftTableMetricComputer(BaseTableMetricComputer):
390
400
  columns, self._build_table("svv_table_info", "pg_catalog"), where_clause
391
401
  )
392
402
  res = self.runner._session.execute(query).first()
393
- if res.rowCount is None:
403
+ if res.rowCount is None or (
404
+ res.rowCount == 0 and self._entity.tableType == TableType.View
405
+ ):
394
406
  # if we don't have any row count, fallback to the base logic
395
407
  return super().compute()
396
408
  return res
@@ -400,9 +412,15 @@ class TableMetricComputer:
400
412
  """Table Metric Construct"""
401
413
 
402
414
  def __init__(
403
- self, dialect: str, runner: QueryRunner, metrics: List[Metrics], conn_config
415
+ self,
416
+ dialect: str,
417
+ runner: QueryRunner,
418
+ metrics: List[Metrics],
419
+ conn_config,
420
+ entity: OMTable,
404
421
  ):
405
422
  """Instantiate table metric computer with a dialect computer"""
423
+ self._entity = entity
406
424
  self._dialect = dialect
407
425
  self._runner = runner
408
426
  self._metrics = metrics
@@ -413,6 +431,7 @@ class TableMetricComputer:
413
431
  runner=self._runner,
414
432
  metrics=self._metrics,
415
433
  conn_config=self._conn_config,
434
+ entity=self._entity,
416
435
  )
417
436
  )
418
437
 
@@ -92,6 +92,7 @@ NOT_COMPUTE = {
92
92
  sqa_types.SQASet.__name__,
93
93
  sqa_types.SQAUnion.__name__,
94
94
  sqa_types.SQASGeography.__name__,
95
+ DataType.GEOMETRY.value,
95
96
  DataType.ARRAY.value,
96
97
  DataType.JSON.value,
97
98
  CustomTypes.ARRAY.value.__name__,
@@ -114,8 +115,6 @@ QUANTIFIABLE_SET = {
114
115
 
115
116
  CONCATENABLE_SET = {DataType.STRING.value, DataType.TEXT.value}
116
117
 
117
- DATATIME_SET = {DataType.DATETIME.value}
118
-
119
118
 
120
119
  # Now, let's define some helper methods to identify
121
120
  # the nature of an SQLAlchemy type
@@ -138,7 +137,11 @@ def is_date_time(_type) -> bool:
138
137
  Check if sqlalchemy _type is derived from Date, Time or DateTime Type
139
138
  """
140
139
  if isinstance(_type, DataType):
141
- return _type.value in DATATIME_SET
140
+ return _type.value in {
141
+ DataType.DATETIME.value,
142
+ DataType.TIME.value,
143
+ DataType.DATE.value,
144
+ }
142
145
  return (
143
146
  issubclass(_type.__class__, Date)
144
147
  or issubclass(_type.__class__, Time)
@@ -16,7 +16,7 @@ from __future__ import annotations
16
16
 
17
17
  import traceback
18
18
  from datetime import datetime, timezone
19
- from typing import Any, Dict, Generic, List, Optional, Set, Tuple, Type, cast
19
+ from typing import Any, Dict, Generic, List, Optional, Set, Tuple, Type
20
20
 
21
21
  from pydantic import ValidationError
22
22
  from sqlalchemy import Column
@@ -25,6 +25,9 @@ from sqlalchemy.orm import DeclarativeMeta
25
25
  from metadata.generated.schema.api.data.createTableProfile import (
26
26
  CreateTableProfileRequest,
27
27
  )
28
+ from metadata.generated.schema.configuration.profilerConfiguration import (
29
+ ProfilerConfiguration,
30
+ )
28
31
  from metadata.generated.schema.entity.data.table import (
29
32
  ColumnName,
30
33
  ColumnProfile,
@@ -33,6 +36,7 @@ from metadata.generated.schema.entity.data.table import (
33
36
  TableData,
34
37
  TableProfile,
35
38
  )
39
+ from metadata.generated.schema.settings.settings import Settings
36
40
  from metadata.generated.schema.tests.customMetric import (
37
41
  CustomMetric as CustomMetricEntity,
38
42
  )
@@ -40,17 +44,15 @@ from metadata.profiler.api.models import ProfilerResponse, ThreadPoolMetrics
40
44
  from metadata.profiler.interface.profiler_interface import ProfilerInterface
41
45
  from metadata.profiler.metrics.core import (
42
46
  ComposedMetric,
43
- CustomMetric,
44
47
  HybridMetric,
45
48
  MetricTypes,
46
49
  QueryMetric,
47
50
  StaticMetric,
48
- SystemMetric,
49
51
  TMetric,
50
52
  )
51
- from metadata.profiler.metrics.registry import Metrics
52
53
  from metadata.profiler.metrics.static.row_count import RowCount
53
54
  from metadata.profiler.orm.registry import NOT_COMPUTE
55
+ from metadata.profiler.processor.metric_filter import MetricFilter
54
56
  from metadata.profiler.processor.sample_data_handler import upload_sample_data
55
57
  from metadata.utils.constants import SAMPLE_DATA_DEFAULT_COUNT
56
58
  from metadata.utils.execution_time_tracker import calculate_execution_time
@@ -76,12 +78,15 @@ class Profiler(Generic[TMetric]):
76
78
  - A tuple of metrics, from which we will construct queries.
77
79
  """
78
80
 
81
+ # pylint: disable=too-many-instance-attributes
82
+
79
83
  def __init__(
80
84
  self,
81
85
  *metrics: Type[TMetric],
82
86
  profiler_interface: ProfilerInterface,
83
87
  include_columns: Optional[List[ColumnProfilerConfig]] = None,
84
88
  exclude_columns: Optional[List[str]] = None,
89
+ global_profiler_configuration: Optional[Settings] = None,
85
90
  ):
86
91
  """
87
92
  :param metrics: Metrics to run. We are receiving the uninitialized classes
@@ -90,7 +95,11 @@ class Profiler(Generic[TMetric]):
90
95
  :param ignore_cols: List of columns to ignore when computing the profile
91
96
  :param profile_sample: % of rows to use for sampling column metrics
92
97
  """
93
-
98
+ self.global_profiler_configuration: Optional[ProfilerConfiguration] = (
99
+ global_profiler_configuration.config_value
100
+ if global_profiler_configuration
101
+ else None
102
+ )
94
103
  self.profiler_interface = profiler_interface
95
104
  self.source_config = self.profiler_interface.source_config
96
105
  self.include_columns = include_columns
@@ -99,6 +108,13 @@ class Profiler(Generic[TMetric]):
99
108
  self._profile_date = int(datetime.now(tz=timezone.utc).timestamp() * 1000)
100
109
  self.profile_sample_config = self.profiler_interface.profile_sample_config
101
110
 
111
+ self.metric_filter = MetricFilter(
112
+ metrics=self.metrics,
113
+ global_profiler_config=self.global_profiler_configuration,
114
+ table_profiler_config=self.profiler_interface.table_entity.tableProfilerConfig,
115
+ column_profiler_config=self.include_columns,
116
+ )
117
+
102
118
  self.validate_composed_metric()
103
119
 
104
120
  # Initialize profiler results
@@ -175,12 +191,6 @@ class Profiler(Generic[TMetric]):
175
191
  return {include_col.columnName for include_col in self.include_columns}
176
192
  return {}
177
193
 
178
- def _filter_metrics(self, _type: Type[TMetric]) -> List[Type[TMetric]]:
179
- """
180
- Filter metrics by type
181
- """
182
- return [metric for metric in self.metrics if issubclass(metric, _type)]
183
-
184
194
  def _check_profile_and_handle(
185
195
  self, profile: CreateTableProfileRequest
186
196
  ) -> CreateTableProfileRequest:
@@ -196,7 +206,10 @@ class Profiler(Generic[TMetric]):
196
206
  CreateTableProfileRequest:
197
207
  """
198
208
  for attrs, val in profile.tableProfile:
199
- if attrs not in {"timestamp", "profileSample", "profileSampleType"} and val:
209
+ if (
210
+ attrs not in {"timestamp", "profileSample", "profileSampleType"}
211
+ and val is not None
212
+ ):
200
213
  return
201
214
 
202
215
  for col_element in profile.columnProfile:
@@ -208,76 +221,6 @@ class Profiler(Generic[TMetric]):
208
221
  f"No profile data computed for {self.profiler_interface.table_entity.fullyQualifiedName.__root__}"
209
222
  )
210
223
 
211
- @property
212
- def static_metrics(self) -> List[Type[StaticMetric]]:
213
- return self._filter_metrics(StaticMetric)
214
-
215
- @property
216
- def composed_metrics(self) -> List[Type[ComposedMetric]]:
217
- return self._filter_metrics(ComposedMetric)
218
-
219
- @property
220
- def custom_metrics(self) -> List[Type[CustomMetric]]:
221
- return self._filter_metrics(CustomMetric)
222
-
223
- @property
224
- def query_metrics(self) -> List[Type[QueryMetric]]:
225
- return self._filter_metrics(QueryMetric)
226
-
227
- @property
228
- def system_metrics(self) -> List[Type[SystemMetric]]:
229
- return self._filter_metrics(SystemMetric)
230
-
231
- @property
232
- def hybrid_metric(self) -> List[Type[HybridMetric]]:
233
- return self._filter_metrics(HybridMetric)
234
-
235
- def get_col_metrics(
236
- self, metrics: List[Type[TMetric]], column: Optional[Column] = None
237
- ) -> List[Type[TMetric]]:
238
- """
239
- Filter list of metrics for column metrics with allowed types
240
- """
241
-
242
- if column is None:
243
- return [metric for metric in metrics if metric.is_col_metric()]
244
-
245
- if (
246
- self.profiler_interface.table_entity.tableProfilerConfig
247
- and self.profiler_interface.table_entity.tableProfilerConfig.includeColumns
248
- ) or (self.include_columns):
249
- # include_columns is set from the `tableConfig` of the `ProfilerProcessorConfig` in the CLI config
250
- # while `self.profiler_interface.table_entity.tableProfilerConfig.includeColumns` is set from the entity
251
- # definition in the metadata service. This gets set either from the UI or the profiler entity page. Config
252
- # ran from the CLI takes precedence over the entity definition.
253
- columns = (
254
- self.include_columns
255
- if self.include_columns
256
- else self.profiler_interface.table_entity.tableProfilerConfig.includeColumns
257
- )
258
- columns = cast(List[ColumnProfilerConfig], columns)
259
- metric_names = next(
260
- (
261
- include_columns.metrics
262
- for include_columns in columns
263
- if include_columns.columnName == column.name
264
- ),
265
- None,
266
- )
267
-
268
- if metric_names:
269
- metric_names = {
270
- mtrc.lower() for mtrc in metric_names
271
- } # case insensitice
272
- metrics = [
273
- Metric.value
274
- for Metric in Metrics
275
- if Metric.value.name().lower() in metric_names
276
- and Metric.value in metrics
277
- ]
278
-
279
- return [metric for metric in metrics if metric.is_col_metric()]
280
-
281
224
  def get_custom_metrics(
282
225
  self, column_name: Optional[str] = None
283
226
  ) -> Optional[List[CustomMetricEntity]]:
@@ -317,7 +260,7 @@ class Profiler(Generic[TMetric]):
317
260
  `required_metrics` attr
318
261
  """
319
262
  names = {metric.name() for metric in self.metrics}
320
- for metric in self.composed_metrics:
263
+ for metric in self.metric_filter.composed_metrics:
321
264
  if not set(metric.required_metrics()).issubset(names):
322
265
  raise MissingMetricException(
323
266
  f"We need {metric.required_metrics()} for {metric.name}, but only got {names} in the profiler"
@@ -339,7 +282,9 @@ class Profiler(Generic[TMetric]):
339
282
  )
340
283
  return
341
284
 
342
- for metric in self.get_col_metrics(self.composed_metrics):
285
+ for metric in self.metric_filter.get_column_metrics(
286
+ ComposedMetric, col, self.profiler_interface.table_entity.serviceType
287
+ ):
343
288
  # Composed metrics require the results as an argument
344
289
  logger.debug(f"Running composed metric {metric.name()} for {col.name}")
345
290
 
@@ -364,7 +309,9 @@ class Profiler(Generic[TMetric]):
364
309
  "We do not have any results to base our Hybrid Metrics. Stopping!"
365
310
  )
366
311
  return
367
- for metric in self.get_col_metrics(self.hybrid_metric, col):
312
+ for metric in self.metric_filter.get_column_metrics(
313
+ HybridMetric, col, self.profiler_interface.table_entity.serviceType
314
+ ):
368
315
  logger.debug(f"Running hybrid metric {metric.name()} for {col.name}")
369
316
  self._column_results[col.name][
370
317
  metric.name()
@@ -380,7 +327,7 @@ class Profiler(Generic[TMetric]):
380
327
  metrics = []
381
328
  table_metrics = [
382
329
  metric
383
- for metric in self.static_metrics
330
+ for metric in self.metric_filter.static_metrics
384
331
  if (not metric.is_col_metric() and not metric.is_system_metrics())
385
332
  ]
386
333
 
@@ -414,7 +361,7 @@ class Profiler(Generic[TMetric]):
414
361
 
415
362
  def _prepare_system_metrics(self) -> List:
416
363
  """prepare system metrics"""
417
- system_metrics = self.system_metrics
364
+ system_metrics = self.metric_filter.system_metrics
418
365
 
419
366
  if system_metrics:
420
367
  return [
@@ -431,17 +378,21 @@ class Profiler(Generic[TMetric]):
431
378
 
432
379
  def _prepare_column_metrics(self) -> List:
433
380
  """prepare column metrics"""
381
+ column_metrics_for_thread_pool = []
434
382
  columns = [
435
383
  column
436
384
  for column in self.columns
437
385
  if column.type.__class__.__name__ not in NOT_COMPUTE
438
386
  ]
439
- column_metrics_for_thread_pool = []
440
387
  static_metrics = [
441
388
  ThreadPoolMetrics(
442
389
  metrics=[
443
390
  metric
444
- for metric in self.get_col_metrics(self.static_metrics, column)
391
+ for metric in self.metric_filter.get_column_metrics(
392
+ StaticMetric,
393
+ column,
394
+ self.profiler_interface.table_entity.serviceType,
395
+ )
445
396
  if not metric.is_window_metric()
446
397
  ],
447
398
  metric_type=MetricTypes.Static,
@@ -458,13 +409,19 @@ class Profiler(Generic[TMetric]):
458
409
  table=self.table,
459
410
  )
460
411
  for column in columns
461
- for metric in self.get_col_metrics(self.query_metrics, column)
412
+ for metric in self.metric_filter.get_column_metrics(
413
+ QueryMetric, column, self.profiler_interface.table_entity.serviceType
414
+ )
462
415
  ]
463
416
  window_metrics = [
464
417
  ThreadPoolMetrics(
465
418
  metrics=[
466
419
  metric
467
- for metric in self.get_col_metrics(self.static_metrics, column)
420
+ for metric in self.metric_filter.get_column_metrics(
421
+ StaticMetric,
422
+ column,
423
+ self.profiler_interface.table_entity.serviceType,
424
+ )
468
425
  if metric.is_window_metric()
469
426
  ],
470
427
  metric_type=MetricTypes.Window,
@@ -628,12 +585,16 @@ class Profiler(Generic[TMetric]):
628
585
  rowCount=self._table_results.get(RowCount.name()),
629
586
  createDateTime=self._table_results.get("createDateTime"),
630
587
  sizeInByte=self._table_results.get("sizeInBytes"),
631
- profileSample=self.profile_sample_config.profile_sample
632
- if self.profile_sample_config
633
- else None,
634
- profileSampleType=self.profile_sample_config.profile_sample_type
635
- if self.profile_sample_config
636
- else None,
588
+ profileSample=(
589
+ self.profile_sample_config.profile_sample
590
+ if self.profile_sample_config
591
+ else None
592
+ ),
593
+ profileSampleType=(
594
+ self.profile_sample_config.profile_sample_type
595
+ if self.profile_sample_config
596
+ else None
597
+ ),
637
598
  customMetrics=self._table_results.get("customMetrics"),
638
599
  )
639
600
 
@@ -16,6 +16,9 @@ from typing import List, Optional
16
16
 
17
17
  from sqlalchemy.orm import DeclarativeMeta
18
18
 
19
+ from metadata.generated.schema.configuration.profilerConfiguration import (
20
+ ProfilerConfiguration,
21
+ )
19
22
  from metadata.generated.schema.entity.data.table import ColumnProfilerConfig
20
23
  from metadata.generated.schema.entity.services.databaseService import DatabaseService
21
24
  from metadata.ingestion.ometa.ometa_api import OpenMetadata
@@ -73,6 +76,7 @@ class DefaultProfiler(Profiler):
73
76
  profiler_interface: ProfilerInterface,
74
77
  include_columns: Optional[List[ColumnProfilerConfig]] = None,
75
78
  exclude_columns: Optional[List[str]] = None,
79
+ global_profiler_configuration: Optional[ProfilerConfiguration] = None,
76
80
  ):
77
81
  _metrics = get_default_metrics(
78
82
  table=profiler_interface.table, ometa_client=profiler_interface.ometa_client
@@ -83,4 +87,5 @@ class DefaultProfiler(Profiler):
83
87
  profiler_interface=profiler_interface,
84
88
  include_columns=include_columns,
85
89
  exclude_columns=exclude_columns,
90
+ global_profiler_configuration=global_profiler_configuration,
86
91
  )
@@ -19,7 +19,7 @@ from typing import List
19
19
  from sqlalchemy import Column, text
20
20
 
21
21
  from metadata.generated.schema.entity.data.table import (
22
- PartitionIntervalType,
22
+ PartitionIntervalTypes,
23
23
  PartitionProfilerConfig,
24
24
  )
25
25
  from metadata.profiler.orm.functions.modulo import ModuloFn
@@ -52,13 +52,13 @@ def build_partition_predicate(
52
52
  _type_: _description_
53
53
  """
54
54
  partition_field = partition_details.partitionColumnName
55
- if partition_details.partitionIntervalType == PartitionIntervalType.COLUMN_VALUE:
55
+ if partition_details.partitionIntervalType == PartitionIntervalTypes.COLUMN_VALUE:
56
56
  return get_value_filter(
57
57
  Column(partition_field),
58
58
  partition_details.partitionValues,
59
59
  )
60
60
 
61
- if partition_details.partitionIntervalType == PartitionIntervalType.INTEGER_RANGE:
61
+ if partition_details.partitionIntervalType == PartitionIntervalTypes.INTEGER_RANGE:
62
62
  return get_integer_range_filter(
63
63
  Column(partition_field),
64
64
  partition_details.partitionIntegerRangeStart,