openmetadata-ingestion 1.3.1.3__py3-none-any.whl → 1.3.2.0rc2__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 (554) hide show
  1. metadata/clients/azure_client.py +85 -0
  2. metadata/data_quality/source/test_suite.py +2 -2
  3. metadata/examples/workflows/datalake_azure_default.yaml +29 -0
  4. metadata/generated/schema/analytics/__init__.py +1 -1
  5. metadata/generated/schema/analytics/basic.py +1 -1
  6. metadata/generated/schema/analytics/reportData.py +1 -1
  7. metadata/generated/schema/analytics/reportDataType/__init__.py +1 -1
  8. metadata/generated/schema/analytics/reportDataType/aggregatedCostAnalysisReportData.py +1 -1
  9. metadata/generated/schema/analytics/reportDataType/entityReportData.py +1 -1
  10. metadata/generated/schema/analytics/reportDataType/rawCostAnalysisReportData.py +1 -1
  11. metadata/generated/schema/analytics/reportDataType/webAnalyticEntityViewReportData.py +1 -1
  12. metadata/generated/schema/analytics/reportDataType/webAnalyticUserActivityReportData.py +1 -1
  13. metadata/generated/schema/analytics/webAnalyticEvent.py +1 -1
  14. metadata/generated/schema/analytics/webAnalyticEventData.py +1 -1
  15. metadata/generated/schema/analytics/webAnalyticEventType/__init__.py +1 -1
  16. metadata/generated/schema/analytics/webAnalyticEventType/customEvent.py +1 -1
  17. metadata/generated/schema/analytics/webAnalyticEventType/pageViewEvent.py +1 -1
  18. metadata/generated/schema/api/__init__.py +1 -1
  19. metadata/generated/schema/api/addGlossaryToAssetsRequest.py +1 -1
  20. metadata/generated/schema/api/analytics/__init__.py +1 -1
  21. metadata/generated/schema/api/analytics/createWebAnalyticEvent.py +1 -1
  22. metadata/generated/schema/api/automations/__init__.py +1 -1
  23. metadata/generated/schema/api/automations/createWorkflow.py +1 -1
  24. metadata/generated/schema/api/bulkAssets.py +1 -1
  25. metadata/generated/schema/api/classification/__init__.py +1 -1
  26. metadata/generated/schema/api/classification/createClassification.py +1 -1
  27. metadata/generated/schema/api/classification/createTag.py +1 -1
  28. metadata/generated/schema/api/classification/loadTags.py +1 -1
  29. metadata/generated/schema/api/createBot.py +1 -1
  30. metadata/generated/schema/api/createEventPublisherJob.py +1 -1
  31. metadata/generated/schema/api/createType.py +1 -1
  32. metadata/generated/schema/api/data/__init__.py +1 -1
  33. metadata/generated/schema/api/data/createChart.py +1 -1
  34. metadata/generated/schema/api/data/createContainer.py +1 -1
  35. metadata/generated/schema/api/data/createCustomProperty.py +1 -1
  36. metadata/generated/schema/api/data/createDashboard.py +1 -1
  37. metadata/generated/schema/api/data/createDashboardDataModel.py +1 -1
  38. metadata/generated/schema/api/data/createDatabase.py +1 -1
  39. metadata/generated/schema/api/data/createDatabaseSchema.py +1 -1
  40. metadata/generated/schema/api/data/createGlossary.py +1 -1
  41. metadata/generated/schema/api/data/createGlossaryTerm.py +1 -1
  42. metadata/generated/schema/api/data/createMlModel.py +1 -1
  43. metadata/generated/schema/api/data/createPipeline.py +1 -1
  44. metadata/generated/schema/api/data/createQuery.py +1 -1
  45. metadata/generated/schema/api/data/createSearchIndex.py +1 -1
  46. metadata/generated/schema/api/data/createStoredProcedure.py +1 -1
  47. metadata/generated/schema/api/data/createTable.py +1 -1
  48. metadata/generated/schema/api/data/createTableProfile.py +1 -1
  49. metadata/generated/schema/api/data/createTopic.py +1 -1
  50. metadata/generated/schema/api/data/loadGlossary.py +1 -1
  51. metadata/generated/schema/api/data/restoreEntity.py +1 -1
  52. metadata/generated/schema/api/dataInsight/__init__.py +1 -1
  53. metadata/generated/schema/api/dataInsight/createDataInsightChart.py +1 -1
  54. metadata/generated/schema/api/dataInsight/kpi/__init__.py +1 -1
  55. metadata/generated/schema/api/dataInsight/kpi/createKpiRequest.py +1 -1
  56. metadata/generated/schema/api/docStore/__init__.py +1 -1
  57. metadata/generated/schema/api/docStore/createDocument.py +1 -1
  58. metadata/generated/schema/api/domains/__init__.py +1 -1
  59. metadata/generated/schema/api/domains/createDataProduct.py +1 -1
  60. metadata/generated/schema/api/domains/createDomain.py +1 -1
  61. metadata/generated/schema/api/feed/__init__.py +1 -1
  62. metadata/generated/schema/api/feed/closeTask.py +1 -1
  63. metadata/generated/schema/api/feed/createPost.py +1 -1
  64. metadata/generated/schema/api/feed/createSuggestion.py +1 -1
  65. metadata/generated/schema/api/feed/createThread.py +5 -1
  66. metadata/generated/schema/api/feed/resolveTask.py +1 -1
  67. metadata/generated/schema/api/feed/threadCount.py +1 -1
  68. metadata/generated/schema/api/lineage/__init__.py +1 -1
  69. metadata/generated/schema/api/lineage/addLineage.py +1 -1
  70. metadata/generated/schema/api/openMetadataServerVersion.py +1 -1
  71. metadata/generated/schema/api/policies/__init__.py +1 -1
  72. metadata/generated/schema/api/policies/createPolicy.py +1 -1
  73. metadata/generated/schema/api/services/__init__.py +1 -1
  74. metadata/generated/schema/api/services/createDashboardService.py +1 -1
  75. metadata/generated/schema/api/services/createDatabaseService.py +1 -1
  76. metadata/generated/schema/api/services/createMessagingService.py +1 -1
  77. metadata/generated/schema/api/services/createMetadataService.py +1 -1
  78. metadata/generated/schema/api/services/createMlModelService.py +1 -1
  79. metadata/generated/schema/api/services/createPipelineService.py +1 -1
  80. metadata/generated/schema/api/services/createSearchService.py +1 -1
  81. metadata/generated/schema/api/services/createStorageService.py +1 -1
  82. metadata/generated/schema/api/services/ingestionPipelines/__init__.py +1 -1
  83. metadata/generated/schema/api/services/ingestionPipelines/createIngestionPipeline.py +1 -1
  84. metadata/generated/schema/api/setOwner.py +1 -1
  85. metadata/generated/schema/api/teams/__init__.py +1 -1
  86. metadata/generated/schema/api/teams/createPersona.py +1 -1
  87. metadata/generated/schema/api/teams/createRole.py +1 -1
  88. metadata/generated/schema/api/teams/createTeam.py +1 -1
  89. metadata/generated/schema/api/teams/createUser.py +1 -1
  90. metadata/generated/schema/api/tests/__init__.py +1 -1
  91. metadata/generated/schema/api/tests/createCustomMetric.py +1 -1
  92. metadata/generated/schema/api/tests/createLogicalTestCases.py +1 -1
  93. metadata/generated/schema/api/tests/createTestCase.py +1 -1
  94. metadata/generated/schema/api/tests/createTestCaseResolutionStatus.py +1 -1
  95. metadata/generated/schema/api/tests/createTestDefinition.py +1 -1
  96. metadata/generated/schema/api/tests/createTestSuite.py +1 -1
  97. metadata/generated/schema/api/voteRequest.py +1 -1
  98. metadata/generated/schema/auth/__init__.py +1 -1
  99. metadata/generated/schema/auth/basicAuth.py +1 -1
  100. metadata/generated/schema/auth/basicLoginRequest.py +1 -1
  101. metadata/generated/schema/auth/changePasswordRequest.py +1 -1
  102. metadata/generated/schema/auth/createPersonalToken.py +1 -1
  103. metadata/generated/schema/auth/emailRequest.py +1 -1
  104. metadata/generated/schema/auth/emailVerificationToken.py +1 -1
  105. metadata/generated/schema/auth/generateToken.py +1 -1
  106. metadata/generated/schema/auth/jwtAuth.py +1 -1
  107. metadata/generated/schema/auth/loginRequest.py +1 -1
  108. metadata/generated/schema/auth/logoutRequest.py +1 -1
  109. metadata/generated/schema/auth/passwordResetRequest.py +1 -1
  110. metadata/generated/schema/auth/passwordResetToken.py +1 -1
  111. metadata/generated/schema/auth/personalAccessToken.py +1 -1
  112. metadata/generated/schema/auth/refreshToken.py +1 -1
  113. metadata/generated/schema/auth/registrationRequest.py +1 -1
  114. metadata/generated/schema/auth/revokePersonalToken.py +1 -1
  115. metadata/generated/schema/auth/revokeToken.py +1 -1
  116. metadata/generated/schema/auth/serviceTokenEnum.py +1 -1
  117. metadata/generated/schema/auth/ssoAuth.py +1 -1
  118. metadata/generated/schema/auth/tokenRefreshRequest.py +1 -1
  119. metadata/generated/schema/configuration/__init__.py +1 -1
  120. metadata/generated/schema/configuration/appsPrivateConfiguration.py +6 -2
  121. metadata/generated/schema/configuration/authConfig.py +1 -1
  122. metadata/generated/schema/configuration/authenticationConfiguration.py +13 -2
  123. metadata/generated/schema/configuration/authorizerConfiguration.py +1 -1
  124. metadata/generated/schema/configuration/changeEventConfiguration.py +1 -1
  125. metadata/generated/schema/configuration/dataQualityConfiguration.py +1 -1
  126. metadata/generated/schema/configuration/elasticSearchConfiguration.py +1 -1
  127. metadata/generated/schema/configuration/eventHandlerConfiguration.py +1 -1
  128. metadata/generated/schema/configuration/fernetConfiguration.py +1 -1
  129. metadata/generated/schema/configuration/jwtTokenConfiguration.py +1 -1
  130. metadata/generated/schema/configuration/kafkaEventConfiguration.py +1 -1
  131. metadata/generated/schema/configuration/ldapConfiguration.py +1 -1
  132. metadata/generated/schema/configuration/ldapTrustStoreConfig/__init__.py +1 -1
  133. metadata/generated/schema/configuration/ldapTrustStoreConfig/customTrustManagerConfig.py +1 -1
  134. metadata/generated/schema/configuration/ldapTrustStoreConfig/hostNameConfig.py +1 -1
  135. metadata/generated/schema/configuration/ldapTrustStoreConfig/jvmDefaultConfig.py +1 -1
  136. metadata/generated/schema/configuration/ldapTrustStoreConfig/trustAllConfig.py +1 -1
  137. metadata/generated/schema/configuration/ldapTrustStoreConfig/truststoreConfig.py +1 -1
  138. metadata/generated/schema/configuration/loginConfiguration.py +1 -1
  139. metadata/generated/schema/configuration/logoConfiguration.py +1 -1
  140. metadata/generated/schema/configuration/pipelineServiceClientConfiguration.py +1 -1
  141. metadata/generated/schema/configuration/slackAppConfiguration.py +1 -1
  142. metadata/generated/schema/configuration/taskNotificationConfiguration.py +1 -1
  143. metadata/generated/schema/configuration/testResultNotificationConfiguration.py +1 -1
  144. metadata/generated/schema/dataInsight/__init__.py +1 -1
  145. metadata/generated/schema/dataInsight/dataInsightChart.py +1 -1
  146. metadata/generated/schema/dataInsight/dataInsightChartResult.py +1 -1
  147. metadata/generated/schema/dataInsight/kpi/__init__.py +1 -1
  148. metadata/generated/schema/dataInsight/kpi/basic.py +1 -1
  149. metadata/generated/schema/dataInsight/kpi/kpi.py +1 -1
  150. metadata/generated/schema/dataInsight/type/__init__.py +1 -1
  151. metadata/generated/schema/dataInsight/type/aggregatedUnusedAssetsCount.py +1 -1
  152. metadata/generated/schema/dataInsight/type/aggregatedUnusedAssetsSize.py +1 -1
  153. metadata/generated/schema/dataInsight/type/aggregatedUsedVsUnusedAssetsCount.py +1 -1
  154. metadata/generated/schema/dataInsight/type/aggregatedUsedVsUnusedAssetsSize.py +1 -1
  155. metadata/generated/schema/dataInsight/type/dailyActiveUsers.py +1 -1
  156. metadata/generated/schema/dataInsight/type/mostActiveUsers.py +1 -1
  157. metadata/generated/schema/dataInsight/type/mostViewedEntities.py +1 -1
  158. metadata/generated/schema/dataInsight/type/pageViewsByEntities.py +1 -1
  159. metadata/generated/schema/dataInsight/type/percentageOfEntitiesWithDescriptionByType.py +1 -1
  160. metadata/generated/schema/dataInsight/type/percentageOfEntitiesWithOwnerByType.py +1 -1
  161. metadata/generated/schema/dataInsight/type/percentageOfServicesWithDescription.py +1 -1
  162. metadata/generated/schema/dataInsight/type/percentageOfServicesWithOwner.py +1 -1
  163. metadata/generated/schema/dataInsight/type/totalEntitiesByTier.py +1 -1
  164. metadata/generated/schema/dataInsight/type/totalEntitiesByType.py +1 -1
  165. metadata/generated/schema/dataInsight/type/unusedAssets.py +1 -1
  166. metadata/generated/schema/email/__init__.py +1 -1
  167. metadata/generated/schema/email/emailRequest.py +1 -1
  168. metadata/generated/schema/email/smtpSettings.py +1 -1
  169. metadata/generated/schema/entity/__init__.py +1 -1
  170. metadata/generated/schema/entity/applications/__init__.py +1 -1
  171. metadata/generated/schema/entity/applications/app.py +7 -2
  172. metadata/generated/schema/entity/applications/appRunRecord.py +2 -7
  173. metadata/generated/schema/entity/applications/configuration/__init__.py +1 -1
  174. metadata/generated/schema/entity/applications/configuration/applicationConfig.py +1 -1
  175. metadata/generated/schema/entity/applications/configuration/external/__init__.py +1 -1
  176. metadata/generated/schema/entity/applications/configuration/external/autoTaggerAppConfig.py +1 -1
  177. metadata/generated/schema/entity/applications/configuration/external/metaPilotAppConfig.py +1 -1
  178. metadata/generated/schema/entity/applications/configuration/internal/__init__.py +1 -1
  179. metadata/generated/schema/entity/applications/configuration/internal/dataInsightsAppConfig.py +1 -1
  180. metadata/generated/schema/entity/applications/configuration/internal/dataInsightsReportAppConfig.py +1 -1
  181. metadata/generated/schema/entity/applications/configuration/internal/searchIndexingAppConfig.py +1 -1
  182. metadata/generated/schema/entity/applications/configuration/private/external/__init__.py +1 -1
  183. metadata/generated/schema/entity/applications/configuration/private/external/metaPilotAppPrivateConfig.py +1 -1
  184. metadata/generated/schema/entity/applications/createAppRequest.py +1 -1
  185. metadata/generated/schema/entity/applications/jobStatus.py +1 -1
  186. metadata/generated/schema/entity/applications/liveExecutionContext.py +1 -1
  187. metadata/generated/schema/entity/applications/marketplace/__init__.py +1 -1
  188. metadata/generated/schema/entity/applications/marketplace/appMarketPlaceDefinition.py +1 -1
  189. metadata/generated/schema/entity/applications/marketplace/createAppMarketPlaceDefinitionReq.py +1 -1
  190. metadata/generated/schema/entity/applications/scheduledExecutionContext.py +1 -1
  191. metadata/generated/schema/entity/automations/__init__.py +1 -1
  192. metadata/generated/schema/entity/automations/testServiceConnection.py +1 -1
  193. metadata/generated/schema/entity/automations/workflow.py +1 -1
  194. metadata/generated/schema/entity/bot.py +1 -1
  195. metadata/generated/schema/entity/classification/__init__.py +1 -1
  196. metadata/generated/schema/entity/classification/classification.py +1 -1
  197. metadata/generated/schema/entity/classification/tag.py +1 -1
  198. metadata/generated/schema/entity/data/__init__.py +1 -1
  199. metadata/generated/schema/entity/data/chart.py +1 -1
  200. metadata/generated/schema/entity/data/container.py +1 -1
  201. metadata/generated/schema/entity/data/dashboard.py +1 -1
  202. metadata/generated/schema/entity/data/dashboardDataModel.py +1 -1
  203. metadata/generated/schema/entity/data/database.py +1 -1
  204. metadata/generated/schema/entity/data/databaseSchema.py +1 -1
  205. metadata/generated/schema/entity/data/glossary.py +1 -1
  206. metadata/generated/schema/entity/data/glossaryTerm.py +1 -1
  207. metadata/generated/schema/entity/data/metrics.py +1 -1
  208. metadata/generated/schema/entity/data/mlmodel.py +1 -1
  209. metadata/generated/schema/entity/data/pipeline.py +1 -1
  210. metadata/generated/schema/entity/data/query.py +1 -1
  211. metadata/generated/schema/entity/data/report.py +1 -1
  212. metadata/generated/schema/entity/data/searchIndex.py +1 -1
  213. metadata/generated/schema/entity/data/storedProcedure.py +1 -1
  214. metadata/generated/schema/entity/data/table.py +1 -1
  215. metadata/generated/schema/entity/data/topic.py +1 -1
  216. metadata/generated/schema/entity/docStore/__init__.py +1 -1
  217. metadata/generated/schema/entity/docStore/document.py +1 -1
  218. metadata/generated/schema/entity/domains/__init__.py +1 -1
  219. metadata/generated/schema/entity/domains/dataProduct.py +1 -1
  220. metadata/generated/schema/entity/domains/domain.py +1 -1
  221. metadata/generated/schema/entity/events/__init__.py +1 -1
  222. metadata/generated/schema/entity/events/webhook.py +1 -1
  223. metadata/generated/schema/entity/feed/__init__.py +1 -1
  224. metadata/generated/schema/entity/feed/suggestion.py +1 -1
  225. metadata/generated/schema/entity/feed/thread.py +12 -1
  226. metadata/generated/schema/entity/policies/__init__.py +1 -1
  227. metadata/generated/schema/entity/policies/accessControl/__init__.py +1 -1
  228. metadata/generated/schema/entity/policies/accessControl/resourceDescriptor.py +1 -1
  229. metadata/generated/schema/entity/policies/accessControl/resourcePermission.py +1 -1
  230. metadata/generated/schema/entity/policies/accessControl/rule.py +1 -1
  231. metadata/generated/schema/entity/policies/filters.py +1 -1
  232. metadata/generated/schema/entity/policies/policy.py +1 -1
  233. metadata/generated/schema/entity/services/__init__.py +1 -1
  234. metadata/generated/schema/entity/services/connections/__init__.py +1 -1
  235. metadata/generated/schema/entity/services/connections/common/__init__.py +1 -1
  236. metadata/generated/schema/entity/services/connections/common/sslCertPaths.py +1 -1
  237. metadata/generated/schema/entity/services/connections/common/sslCertValues.py +1 -1
  238. metadata/generated/schema/entity/services/connections/common/sslConfig.py +1 -1
  239. metadata/generated/schema/entity/services/connections/connectionBasicType.py +6 -1
  240. metadata/generated/schema/entity/services/connections/dashboard/__init__.py +1 -1
  241. metadata/generated/schema/entity/services/connections/dashboard/customDashboardConnection.py +1 -1
  242. metadata/generated/schema/entity/services/connections/dashboard/domoDashboardConnection.py +1 -1
  243. metadata/generated/schema/entity/services/connections/dashboard/lightdashConnection.py +1 -1
  244. metadata/generated/schema/entity/services/connections/dashboard/lookerConnection.py +1 -1
  245. metadata/generated/schema/entity/services/connections/dashboard/metabaseConnection.py +1 -1
  246. metadata/generated/schema/entity/services/connections/dashboard/modeConnection.py +1 -1
  247. metadata/generated/schema/entity/services/connections/dashboard/mstrConnection.py +1 -1
  248. metadata/generated/schema/entity/services/connections/dashboard/powerBIConnection.py +1 -1
  249. metadata/generated/schema/entity/services/connections/dashboard/qlikSenseConnection.py +1 -1
  250. metadata/generated/schema/entity/services/connections/dashboard/quickSightConnection.py +1 -1
  251. metadata/generated/schema/entity/services/connections/dashboard/redashConnection.py +1 -1
  252. metadata/generated/schema/entity/services/connections/dashboard/supersetConnection.py +1 -1
  253. metadata/generated/schema/entity/services/connections/dashboard/tableauConnection.py +1 -1
  254. metadata/generated/schema/entity/services/connections/database/__init__.py +1 -1
  255. metadata/generated/schema/entity/services/connections/database/athenaConnection.py +1 -1
  256. metadata/generated/schema/entity/services/connections/database/azureSQLConnection.py +34 -1
  257. metadata/generated/schema/entity/services/connections/database/bigQueryConnection.py +1 -1
  258. metadata/generated/schema/entity/services/connections/database/bigTableConnection.py +1 -1
  259. metadata/generated/schema/entity/services/connections/database/clickhouseConnection.py +1 -1
  260. metadata/generated/schema/entity/services/connections/database/common/__init__.py +1 -1
  261. metadata/generated/schema/entity/services/connections/database/common/azureConfig.py +20 -0
  262. metadata/generated/schema/entity/services/connections/database/common/basicAuth.py +1 -1
  263. metadata/generated/schema/entity/services/connections/database/common/iamAuthConfig.py +1 -1
  264. metadata/generated/schema/entity/services/connections/database/common/jwtAuth.py +1 -1
  265. metadata/generated/schema/entity/services/connections/database/couchbaseConnection.py +1 -1
  266. metadata/generated/schema/entity/services/connections/database/customDatabaseConnection.py +1 -1
  267. metadata/generated/schema/entity/services/connections/database/databricksConnection.py +1 -1
  268. metadata/generated/schema/entity/services/connections/database/datalake/__init__.py +1 -1
  269. metadata/generated/schema/entity/services/connections/database/datalake/azureConfig.py +1 -1
  270. metadata/generated/schema/entity/services/connections/database/datalake/gcsConfig.py +1 -1
  271. metadata/generated/schema/entity/services/connections/database/datalake/s3Config.py +1 -1
  272. metadata/generated/schema/entity/services/connections/database/datalakeConnection.py +1 -1
  273. metadata/generated/schema/entity/services/connections/database/db2Connection.py +1 -1
  274. metadata/generated/schema/entity/services/connections/database/deltaLakeConnection.py +1 -1
  275. metadata/generated/schema/entity/services/connections/database/domoDatabaseConnection.py +1 -1
  276. metadata/generated/schema/entity/services/connections/database/dorisConnection.py +1 -1
  277. metadata/generated/schema/entity/services/connections/database/druidConnection.py +1 -1
  278. metadata/generated/schema/entity/services/connections/database/dynamoDBConnection.py +1 -1
  279. metadata/generated/schema/entity/services/connections/database/glueConnection.py +1 -1
  280. metadata/generated/schema/entity/services/connections/database/greenplumConnection.py +1 -1
  281. metadata/generated/schema/entity/services/connections/database/hiveConnection.py +1 -1
  282. metadata/generated/schema/entity/services/connections/database/iceberg/__init__.py +1 -1
  283. metadata/generated/schema/entity/services/connections/database/iceberg/dynamoDbCatalogConnection.py +1 -1
  284. metadata/generated/schema/entity/services/connections/database/iceberg/glueCatalogConnection.py +1 -1
  285. metadata/generated/schema/entity/services/connections/database/iceberg/hiveCatalogConnection.py +1 -1
  286. metadata/generated/schema/entity/services/connections/database/iceberg/icebergCatalog.py +1 -1
  287. metadata/generated/schema/entity/services/connections/database/iceberg/icebergFileSystem.py +1 -1
  288. metadata/generated/schema/entity/services/connections/database/iceberg/restCatalogConnection.py +1 -1
  289. metadata/generated/schema/entity/services/connections/database/icebergConnection.py +1 -1
  290. metadata/generated/schema/entity/services/connections/database/impalaConnection.py +1 -1
  291. metadata/generated/schema/entity/services/connections/database/mariaDBConnection.py +1 -1
  292. metadata/generated/schema/entity/services/connections/database/mongoDBConnection.py +1 -1
  293. metadata/generated/schema/entity/services/connections/database/mssqlConnection.py +1 -1
  294. metadata/generated/schema/entity/services/connections/database/mysqlConnection.py +7 -3
  295. metadata/generated/schema/entity/services/connections/database/oracleConnection.py +1 -1
  296. metadata/generated/schema/entity/services/connections/database/pinotDBConnection.py +1 -1
  297. metadata/generated/schema/entity/services/connections/database/postgresConnection.py +7 -3
  298. metadata/generated/schema/entity/services/connections/database/prestoConnection.py +1 -1
  299. metadata/generated/schema/entity/services/connections/database/redshiftConnection.py +1 -1
  300. metadata/generated/schema/entity/services/connections/database/salesforceConnection.py +1 -1
  301. metadata/generated/schema/entity/services/connections/database/sapHana/__init__.py +3 -0
  302. metadata/generated/schema/entity/services/connections/database/sapHana/sapHanaHDBConnection.py +20 -0
  303. metadata/generated/schema/entity/services/connections/database/sapHana/sapHanaSQLConnection.py +36 -0
  304. metadata/generated/schema/entity/services/connections/database/sapHanaConnection.py +6 -40
  305. metadata/generated/schema/entity/services/connections/database/sasConnection.py +1 -1
  306. metadata/generated/schema/entity/services/connections/database/singleStoreConnection.py +1 -1
  307. metadata/generated/schema/entity/services/connections/database/snowflakeConnection.py +1 -1
  308. metadata/generated/schema/entity/services/connections/database/sqliteConnection.py +1 -1
  309. metadata/generated/schema/entity/services/connections/database/trinoConnection.py +1 -1
  310. metadata/generated/schema/entity/services/connections/database/unityCatalogConnection.py +1 -1
  311. metadata/generated/schema/entity/services/connections/database/verticaConnection.py +1 -1
  312. metadata/generated/schema/entity/services/connections/messaging/__init__.py +1 -1
  313. metadata/generated/schema/entity/services/connections/messaging/customMessagingConnection.py +1 -1
  314. metadata/generated/schema/entity/services/connections/messaging/kafkaConnection.py +1 -1
  315. metadata/generated/schema/entity/services/connections/messaging/kinesisConnection.py +1 -1
  316. metadata/generated/schema/entity/services/connections/messaging/pulsarConnection.py +1 -1
  317. metadata/generated/schema/entity/services/connections/messaging/redpandaConnection.py +1 -1
  318. metadata/generated/schema/entity/services/connections/messaging/saslMechanismType.py +1 -1
  319. metadata/generated/schema/entity/services/connections/metadata/__init__.py +1 -1
  320. metadata/generated/schema/entity/services/connections/metadata/alationConnection.py +1 -1
  321. metadata/generated/schema/entity/services/connections/metadata/amundsenConnection.py +1 -1
  322. metadata/generated/schema/entity/services/connections/metadata/atlasConnection.py +1 -1
  323. metadata/generated/schema/entity/services/connections/metadata/metadataESConnection.py +1 -1
  324. metadata/generated/schema/entity/services/connections/metadata/openMetadataConnection.py +1 -1
  325. metadata/generated/schema/entity/services/connections/mlmodel/__init__.py +1 -1
  326. metadata/generated/schema/entity/services/connections/mlmodel/customMlModelConnection.py +1 -1
  327. metadata/generated/schema/entity/services/connections/mlmodel/mlflowConnection.py +1 -1
  328. metadata/generated/schema/entity/services/connections/mlmodel/sageMakerConnection.py +1 -1
  329. metadata/generated/schema/entity/services/connections/mlmodel/sklearnConnection.py +1 -1
  330. metadata/generated/schema/entity/services/connections/pipeline/__init__.py +1 -1
  331. metadata/generated/schema/entity/services/connections/pipeline/airbyteConnection.py +1 -1
  332. metadata/generated/schema/entity/services/connections/pipeline/airflowConnection.py +1 -1
  333. metadata/generated/schema/entity/services/connections/pipeline/backendConnection.py +1 -1
  334. metadata/generated/schema/entity/services/connections/pipeline/customPipelineConnection.py +1 -1
  335. metadata/generated/schema/entity/services/connections/pipeline/dagsterConnection.py +1 -1
  336. metadata/generated/schema/entity/services/connections/pipeline/databricksPipelineConnection.py +1 -1
  337. metadata/generated/schema/entity/services/connections/pipeline/domoPipelineConnection.py +1 -1
  338. metadata/generated/schema/entity/services/connections/pipeline/fivetranConnection.py +1 -1
  339. metadata/generated/schema/entity/services/connections/pipeline/gluePipelineConnection.py +1 -1
  340. metadata/generated/schema/entity/services/connections/pipeline/nifiConnection.py +1 -1
  341. metadata/generated/schema/entity/services/connections/pipeline/sparkConnection.py +1 -1
  342. metadata/generated/schema/entity/services/connections/pipeline/splineConnection.py +1 -1
  343. metadata/generated/schema/entity/services/connections/search/__init__.py +1 -1
  344. metadata/generated/schema/entity/services/connections/search/customSearchConnection.py +1 -1
  345. metadata/generated/schema/entity/services/connections/search/elasticSearch/__init__.py +1 -1
  346. metadata/generated/schema/entity/services/connections/search/elasticSearch/apiAuth.py +1 -1
  347. metadata/generated/schema/entity/services/connections/search/elasticSearch/basicAuth.py +1 -1
  348. metadata/generated/schema/entity/services/connections/search/elasticSearchConnection.py +1 -1
  349. metadata/generated/schema/entity/services/connections/search/openSearchConnection.py +1 -1
  350. metadata/generated/schema/entity/services/connections/serviceConnection.py +1 -1
  351. metadata/generated/schema/entity/services/connections/storage/__init__.py +1 -1
  352. metadata/generated/schema/entity/services/connections/storage/adlsConnection.py +1 -1
  353. metadata/generated/schema/entity/services/connections/storage/customStorageConnection.py +1 -1
  354. metadata/generated/schema/entity/services/connections/storage/gcsConnection.py +1 -1
  355. metadata/generated/schema/entity/services/connections/storage/s3Connection.py +1 -1
  356. metadata/generated/schema/entity/services/connections/testConnectionDefinition.py +1 -1
  357. metadata/generated/schema/entity/services/connections/testConnectionResult.py +1 -1
  358. metadata/generated/schema/entity/services/dashboardService.py +1 -1
  359. metadata/generated/schema/entity/services/databaseService.py +1 -1
  360. metadata/generated/schema/entity/services/ingestionPipelines/__init__.py +1 -1
  361. metadata/generated/schema/entity/services/ingestionPipelines/ingestionPipeline.py +1 -1
  362. metadata/generated/schema/entity/services/ingestionPipelines/pipelineServiceClientResponse.py +1 -1
  363. metadata/generated/schema/entity/services/ingestionPipelines/status.py +1 -1
  364. metadata/generated/schema/entity/services/messagingService.py +1 -1
  365. metadata/generated/schema/entity/services/metadataService.py +1 -1
  366. metadata/generated/schema/entity/services/mlmodelService.py +1 -1
  367. metadata/generated/schema/entity/services/pipelineService.py +1 -1
  368. metadata/generated/schema/entity/services/searchService.py +1 -1
  369. metadata/generated/schema/entity/services/serviceType.py +1 -1
  370. metadata/generated/schema/entity/services/storageService.py +1 -1
  371. metadata/generated/schema/entity/teams/__init__.py +1 -1
  372. metadata/generated/schema/entity/teams/persona.py +1 -1
  373. metadata/generated/schema/entity/teams/role.py +1 -1
  374. metadata/generated/schema/entity/teams/team.py +1 -1
  375. metadata/generated/schema/entity/teams/teamHierarchy.py +1 -1
  376. metadata/generated/schema/entity/teams/user.py +1 -1
  377. metadata/generated/schema/entity/type.py +1 -1
  378. metadata/generated/schema/entity/utils/__init__.py +1 -1
  379. metadata/generated/schema/entity/utils/entitiesCount.py +1 -1
  380. metadata/generated/schema/entity/utils/servicesCount.py +1 -1
  381. metadata/generated/schema/entity/utils/supersetApiConnection.py +1 -1
  382. metadata/generated/schema/events/__init__.py +1 -1
  383. metadata/generated/schema/events/alertMetrics.py +1 -1
  384. metadata/generated/schema/events/api/__init__.py +1 -1
  385. metadata/generated/schema/events/api/createEventSubscription.py +1 -1
  386. metadata/generated/schema/events/emailAlertConfig.py +1 -1
  387. metadata/generated/schema/events/eventFilterRule.py +1 -1
  388. metadata/generated/schema/events/eventSubscription.py +1 -1
  389. metadata/generated/schema/events/eventSubscriptionOffset.py +1 -1
  390. metadata/generated/schema/events/failedEvent.py +1 -1
  391. metadata/generated/schema/events/filterResourceDescriptor.py +1 -1
  392. metadata/generated/schema/events/subscriptionResourceDescriptor.py +1 -1
  393. metadata/generated/schema/metadataIngestion/__init__.py +1 -1
  394. metadata/generated/schema/metadataIngestion/application.py +1 -1
  395. metadata/generated/schema/metadataIngestion/applicationPipeline.py +1 -1
  396. metadata/generated/schema/metadataIngestion/dashboardServiceMetadataPipeline.py +1 -1
  397. metadata/generated/schema/metadataIngestion/dataInsightPipeline.py +1 -1
  398. metadata/generated/schema/metadataIngestion/databaseServiceMetadataPipeline.py +1 -1
  399. metadata/generated/schema/metadataIngestion/databaseServiceProfilerPipeline.py +1 -1
  400. metadata/generated/schema/metadataIngestion/databaseServiceQueryLineagePipeline.py +1 -1
  401. metadata/generated/schema/metadataIngestion/databaseServiceQueryUsagePipeline.py +1 -1
  402. metadata/generated/schema/metadataIngestion/dbtPipeline.py +1 -1
  403. metadata/generated/schema/metadataIngestion/dbtconfig/__init__.py +1 -1
  404. metadata/generated/schema/metadataIngestion/dbtconfig/dbtAzureConfig.py +1 -1
  405. metadata/generated/schema/metadataIngestion/dbtconfig/dbtBucketDetails.py +1 -1
  406. metadata/generated/schema/metadataIngestion/dbtconfig/dbtCloudConfig.py +1 -1
  407. metadata/generated/schema/metadataIngestion/dbtconfig/dbtGCSConfig.py +1 -1
  408. metadata/generated/schema/metadataIngestion/dbtconfig/dbtHttpConfig.py +1 -1
  409. metadata/generated/schema/metadataIngestion/dbtconfig/dbtLocalConfig.py +1 -1
  410. metadata/generated/schema/metadataIngestion/dbtconfig/dbtS3Config.py +1 -1
  411. metadata/generated/schema/metadataIngestion/messagingServiceMetadataPipeline.py +1 -1
  412. metadata/generated/schema/metadataIngestion/metadataToElasticSearchPipeline.py +1 -1
  413. metadata/generated/schema/metadataIngestion/mlmodelServiceMetadataPipeline.py +1 -1
  414. metadata/generated/schema/metadataIngestion/pipelineServiceMetadataPipeline.py +1 -1
  415. metadata/generated/schema/metadataIngestion/searchServiceMetadataPipeline.py +1 -1
  416. metadata/generated/schema/metadataIngestion/storage/__init__.py +1 -1
  417. metadata/generated/schema/metadataIngestion/storage/containerMetadataConfig.py +1 -1
  418. metadata/generated/schema/metadataIngestion/storage/manifestMetadataConfig.py +1 -1
  419. metadata/generated/schema/metadataIngestion/storage/storageBucketDetails.py +1 -1
  420. metadata/generated/schema/metadataIngestion/storage/storageMetadataADLSConfig.py +1 -1
  421. metadata/generated/schema/metadataIngestion/storage/storageMetadataGCSConfig.py +1 -1
  422. metadata/generated/schema/metadataIngestion/storage/storageMetadataHttpConfig.py +1 -1
  423. metadata/generated/schema/metadataIngestion/storage/storageMetadataLocalConfig.py +1 -1
  424. metadata/generated/schema/metadataIngestion/storage/storageMetadataS3Config.py +1 -1
  425. metadata/generated/schema/metadataIngestion/storageServiceMetadataPipeline.py +1 -1
  426. metadata/generated/schema/metadataIngestion/testSuitePipeline.py +1 -1
  427. metadata/generated/schema/metadataIngestion/workflow.py +1 -1
  428. metadata/generated/schema/monitoring/__init__.py +1 -1
  429. metadata/generated/schema/monitoring/eventMonitorProvider.py +1 -1
  430. metadata/generated/schema/security/__init__.py +1 -1
  431. metadata/generated/schema/security/client/__init__.py +1 -1
  432. metadata/generated/schema/security/client/auth0SSOClientConfig.py +1 -1
  433. metadata/generated/schema/security/client/azureSSOClientConfig.py +1 -1
  434. metadata/generated/schema/security/client/customOidcSSOClientConfig.py +1 -1
  435. metadata/generated/schema/security/client/googleSSOClientConfig.py +1 -1
  436. metadata/generated/schema/security/client/oidcClientConfig.py +46 -0
  437. metadata/generated/schema/security/client/oktaSSOClientConfig.py +1 -1
  438. metadata/generated/schema/security/client/openMetadataJWTClientConfig.py +1 -1
  439. metadata/generated/schema/security/client/samlSSOClientConfig.py +1 -1
  440. metadata/generated/schema/security/credentials/__init__.py +1 -1
  441. metadata/generated/schema/security/credentials/accessTokenAuth.py +1 -1
  442. metadata/generated/schema/security/credentials/apiAccessTokenAuth.py +1 -1
  443. metadata/generated/schema/security/credentials/awsCredentials.py +1 -1
  444. metadata/generated/schema/security/credentials/azureCredentials.py +6 -1
  445. metadata/generated/schema/security/credentials/basicAuth.py +1 -1
  446. metadata/generated/schema/security/credentials/bitbucketCredentials.py +1 -1
  447. metadata/generated/schema/security/credentials/gcpCredentials.py +7 -3
  448. metadata/generated/schema/security/credentials/gcpExternalAccount.py +37 -0
  449. metadata/generated/schema/security/credentials/gcpValues.py +2 -2
  450. metadata/generated/schema/security/credentials/gitCredentials.py +1 -1
  451. metadata/generated/schema/security/credentials/githubCredentials.py +1 -1
  452. metadata/generated/schema/security/secrets/__init__.py +1 -1
  453. metadata/generated/schema/security/secrets/secretsManagerClientLoader.py +1 -1
  454. metadata/generated/schema/security/secrets/secretsManagerConfiguration.py +1 -1
  455. metadata/generated/schema/security/secrets/secretsManagerProvider.py +1 -1
  456. metadata/generated/schema/security/securityConfiguration.py +1 -1
  457. metadata/generated/schema/security/ssl/__init__.py +1 -1
  458. metadata/generated/schema/security/ssl/validateSSLClientConfig.py +1 -1
  459. metadata/generated/schema/security/ssl/verifySSLConfig.py +1 -1
  460. metadata/generated/schema/settings/__init__.py +1 -1
  461. metadata/generated/schema/settings/settings.py +1 -1
  462. metadata/generated/schema/system/__init__.py +1 -1
  463. metadata/generated/schema/system/entityError.py +1 -1
  464. metadata/generated/schema/system/eventPublisherJob.py +1 -1
  465. metadata/generated/schema/system/indexingError.py +1 -1
  466. metadata/generated/schema/system/ui/__init__.py +1 -1
  467. metadata/generated/schema/system/ui/knowledgePanel.py +1 -1
  468. metadata/generated/schema/system/ui/page.py +1 -1
  469. metadata/generated/schema/system/validationResponse.py +43 -0
  470. metadata/generated/schema/tests/__init__.py +1 -1
  471. metadata/generated/schema/tests/assigned.py +1 -1
  472. metadata/generated/schema/tests/basic.py +1 -1
  473. metadata/generated/schema/tests/customMetric.py +1 -1
  474. metadata/generated/schema/tests/resolved.py +1 -1
  475. metadata/generated/schema/tests/testCase.py +1 -1
  476. metadata/generated/schema/tests/testCaseResolutionStatus.py +1 -1
  477. metadata/generated/schema/tests/testDefinition.py +1 -1
  478. metadata/generated/schema/tests/testSuite.py +1 -1
  479. metadata/generated/schema/type/__init__.py +1 -1
  480. metadata/generated/schema/type/auditLog.py +1 -1
  481. metadata/generated/schema/type/basic.py +1 -1
  482. metadata/generated/schema/type/bulkOperationResult.py +1 -1
  483. metadata/generated/schema/type/changeEvent.py +1 -1
  484. metadata/generated/schema/type/changeEventType.py +1 -1
  485. metadata/generated/schema/type/collectionDescriptor.py +1 -1
  486. metadata/generated/schema/type/csvDocumentation.py +1 -1
  487. metadata/generated/schema/type/csvErrorType.py +1 -1
  488. metadata/generated/schema/type/csvFile.py +1 -1
  489. metadata/generated/schema/type/csvImportResult.py +1 -1
  490. metadata/generated/schema/type/customProperties/__init__.py +1 -1
  491. metadata/generated/schema/type/customProperties/enumConfig.py +1 -1
  492. metadata/generated/schema/type/customProperty.py +1 -1
  493. metadata/generated/schema/type/dailyCount.py +1 -1
  494. metadata/generated/schema/type/databaseConnectionConfig.py +1 -1
  495. metadata/generated/schema/type/entityHistory.py +1 -1
  496. metadata/generated/schema/type/entityLineage.py +1 -1
  497. metadata/generated/schema/type/entityReference.py +1 -1
  498. metadata/generated/schema/type/entityReferenceList.py +1 -1
  499. metadata/generated/schema/type/entityRelationship.py +1 -1
  500. metadata/generated/schema/type/entityUsage.py +1 -1
  501. metadata/generated/schema/type/filterPattern.py +1 -1
  502. metadata/generated/schema/type/function.py +1 -1
  503. metadata/generated/schema/type/include.py +1 -1
  504. metadata/generated/schema/type/jdbcConnection.py +1 -1
  505. metadata/generated/schema/type/lifeCycle.py +1 -1
  506. metadata/generated/schema/type/paging.py +1 -1
  507. metadata/generated/schema/type/profile.py +1 -1
  508. metadata/generated/schema/type/queryParserData.py +1 -1
  509. metadata/generated/schema/type/reaction.py +1 -1
  510. metadata/generated/schema/type/schedule.py +1 -1
  511. metadata/generated/schema/type/schema.py +1 -1
  512. metadata/generated/schema/type/tableQuery.py +1 -1
  513. metadata/generated/schema/type/tableUsageCount.py +1 -1
  514. metadata/generated/schema/type/tagLabel.py +1 -1
  515. metadata/generated/schema/type/usageDetails.py +1 -1
  516. metadata/generated/schema/type/usageRequest.py +1 -1
  517. metadata/generated/schema/type/votes.py +1 -1
  518. metadata/great_expectations/action.py +5 -3
  519. metadata/ingestion/api/topology_runner.py +4 -3
  520. metadata/ingestion/lineage/parser.py +4 -1
  521. metadata/ingestion/ometa/mixins/patch_mixin.py +2 -4
  522. metadata/ingestion/source/dashboard/powerbi/client.py +4 -1
  523. metadata/ingestion/source/database/azuresql/connection.py +21 -3
  524. metadata/ingestion/source/database/datalake/connection.py +2 -14
  525. metadata/ingestion/source/database/datalake/metadata.py +3 -2
  526. metadata/ingestion/source/database/dbt/dbt_config.py +2 -14
  527. metadata/ingestion/source/database/mssql/lineage.py +1 -0
  528. metadata/ingestion/source/database/mssql/usage.py +5 -1
  529. metadata/ingestion/source/database/mysql/connection.py +14 -0
  530. metadata/ingestion/source/database/postgres/connection.py +15 -0
  531. metadata/ingestion/source/database/stored_procedures_mixin.py +1 -1
  532. metadata/ingestion/source/storage/storage_service.py +5 -2
  533. metadata/parsers/json_schema_parser.py +17 -7
  534. metadata/pii/scanners/ner_scanner.py +5 -3
  535. metadata/profiler/interface/profiler_interface.py +4 -4
  536. metadata/profiler/processor/sample_data_handler.py +45 -8
  537. metadata/profiler/source/databricks/profiler_source.py +36 -0
  538. metadata/profiler/source/metadata.py +7 -1
  539. metadata/profiler/source/profiler_source_factory.py +8 -0
  540. metadata/readers/dataframe/json.py +11 -6
  541. metadata/readers/dataframe/models.py +1 -0
  542. metadata/utils/credentials.py +36 -19
  543. metadata/utils/datalake/datalake_utils.py +34 -4
  544. metadata/utils/secrets/azure_kv_secrets_manager.py +3 -19
  545. metadata/utils/source_hash.py +23 -13
  546. metadata/utils/storage_metadata_config.py +2 -15
  547. metadata/workflow/base.py +1 -1
  548. {openmetadata_ingestion-1.3.1.3.dist-info → openmetadata_ingestion-1.3.2.0rc2.dist-info}/METADATA +292 -292
  549. {openmetadata_ingestion-1.3.1.3.dist-info → openmetadata_ingestion-1.3.2.0rc2.dist-info}/RECORD +554 -544
  550. /metadata/examples/workflows/{datalake_azure.yaml → datalake_azure_client_secret.yaml} +0 -0
  551. {openmetadata_ingestion-1.3.1.3.dist-info → openmetadata_ingestion-1.3.2.0rc2.dist-info}/LICENSE +0 -0
  552. {openmetadata_ingestion-1.3.1.3.dist-info → openmetadata_ingestion-1.3.2.0rc2.dist-info}/WHEEL +0 -0
  553. {openmetadata_ingestion-1.3.1.3.dist-info → openmetadata_ingestion-1.3.2.0rc2.dist-info}/entry_points.txt +0 -0
  554. {openmetadata_ingestion-1.3.1.3.dist-info → openmetadata_ingestion-1.3.2.0rc2.dist-info}/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/profile.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/queryParserData.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/reaction.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/schedule.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/schema.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/tableQuery.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/tableUsageCount.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/tagLabel.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/usageDetails.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/usageRequest.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -1,6 +1,6 @@
1
1
  # generated by datamodel-codegen:
2
2
  # filename: type/votes.json
3
- # timestamp: 2024-03-19T09:19:01+00:00
3
+ # timestamp: 2024-03-26T16:14:58+00:00
4
4
 
5
5
  from __future__ import annotations
6
6
 
@@ -15,6 +15,7 @@ Open Metadata table quality.
15
15
  This subpackage needs to be used in Great Expectations
16
16
  checkpoints actions.
17
17
  """
18
+ import logging
18
19
  import traceback
19
20
  from datetime import datetime, timezone
20
21
  from typing import Dict, List, Optional, Union, cast
@@ -72,9 +73,10 @@ from metadata.great_expectations.utils.ometa_config_handler import (
72
73
  from metadata.ingestion.ometa.ometa_api import OpenMetadata
73
74
  from metadata.utils import fqn
74
75
  from metadata.utils.entity_link import get_entity_link
75
- from metadata.utils.logger import great_expectations_logger
76
76
 
77
- logger = great_expectations_logger()
77
+ logger = logging.getLogger(
78
+ "great_expectations.validation_operators.validation_operators.openmetadata"
79
+ )
78
80
 
79
81
 
80
82
  class OpenMetadataValidationAction(ValidationAction):
@@ -429,7 +431,7 @@ class OpenMetadataValidationAction(ValidationAction):
429
431
  test_case_fqn=test_case.fullyQualifiedName.__root__,
430
432
  )
431
433
 
432
- logger.info(
434
+ logger.debug(
433
435
  f"Test case result for {test_case.fullyQualifiedName.__root__} successfully ingested"
434
436
  )
435
437
 
@@ -265,11 +265,12 @@ class TopologyRunnerMixin(Generic[C]):
265
265
  if entity:
266
266
  same_fingerprint = True
267
267
 
268
- create_entity_request_hash = generate_source_hash(
269
- create_request=entity_request.right,
270
- )
268
+ create_entity_request_hash = None
271
269
 
272
270
  if hasattr(entity_request.right, "sourceHash"):
271
+ create_entity_request_hash = generate_source_hash(
272
+ create_request=entity_request.right,
273
+ )
273
274
  entity_request.right.sourceHash = create_entity_request_hash
274
275
 
275
276
  if entity is None and stage.use_cache:
@@ -319,7 +319,10 @@ class LineageParser:
319
319
  )
320
320
 
321
321
  if not table_left or not table_right:
322
- logger.warning(f"Cannot find ingredients from {comparison}")
322
+ logger.warning(
323
+ f"Can't extract table names when parsing JOIN information from {comparison}"
324
+ )
325
+ logger.debug(f"Query: {sql_statement}")
323
326
  continue
324
327
 
325
328
  left_table_column = TableColumn(table=table_left, column=column_left)
@@ -46,7 +46,7 @@ from metadata.ingestion.ometa.mixins.patch_mixin_utils import (
46
46
  )
47
47
  from metadata.ingestion.ometa.utils import model_str
48
48
  from metadata.utils.deprecation import deprecated
49
- from metadata.utils.logger import ometa_logger
49
+ from metadata.utils.logger import get_log_name, ometa_logger
50
50
 
51
51
  logger = ometa_logger()
52
52
 
@@ -155,9 +155,7 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
155
155
 
156
156
  except Exception as exc:
157
157
  logger.debug(traceback.format_exc())
158
- logger.error(
159
- f"Error trying to PATCH {entity.__name__} [{source.id.__root__}]: {exc}"
160
- )
158
+ logger.error(f"Error trying to PATCH {get_log_name(source)}: {exc}")
161
159
 
162
160
  return None
163
161
 
@@ -19,6 +19,9 @@ from typing import List, Optional, Tuple
19
19
 
20
20
  import msal
21
21
 
22
+ from metadata.generated.schema.entity.services.connections.dashboard.powerBIConnection import (
23
+ PowerBIConnection,
24
+ )
22
25
  from metadata.ingestion.api.steps import InvalidSourceException
23
26
  from metadata.ingestion.ometa.client import REST, ClientConfig
24
27
  from metadata.ingestion.source.dashboard.powerbi.models import (
@@ -52,7 +55,7 @@ class PowerBiApiClient:
52
55
 
53
56
  client: REST
54
57
 
55
- def __init__(self, config):
58
+ def __init__(self, config: PowerBIConnection):
56
59
  self.config = config
57
60
  self.msal_client = msal.ConfidentialClientApplication(
58
61
  client_id=self.config.clientId,
@@ -15,12 +15,13 @@ Source connection handler
15
15
  from typing import Optional, Union
16
16
  from urllib.parse import quote_plus
17
17
 
18
- from sqlalchemy.engine import Engine
18
+ from sqlalchemy.engine import URL, Engine
19
19
 
20
20
  from metadata.generated.schema.entity.automations.workflow import (
21
21
  Workflow as AutomationWorkflow,
22
22
  )
23
23
  from metadata.generated.schema.entity.services.connections.database.azureSQLConnection import (
24
+ Authentication,
24
25
  AzureSQLConnection,
25
26
  )
26
27
  from metadata.generated.schema.entity.services.connections.database.mssqlConnection import (
@@ -40,13 +41,29 @@ def get_connection_url(connection: Union[AzureSQLConnection, MssqlConnection]) -
40
41
  Build the connection URL
41
42
  """
42
43
 
44
+ if connection.authenticationMode:
45
+ connection_string = f"Driver={connection.driver};Server={connection.hostPort};Database={connection.database};"
46
+ connection_string += f"Uid={connection.username};"
47
+ if (
48
+ connection.authenticationMode.authentication
49
+ == Authentication.ActiveDirectoryPassword
50
+ ):
51
+ connection_string += f"Pwd={connection.password.get_secret_value()};"
52
+
53
+ connection_string += f"Encrypt={'yes' if connection.authenticationMode.encrypt else 'no'};TrustServerCertificate={'yes' if connection.authenticationMode.trustServerCertificate else 'no'};"
54
+ connection_string += f"Connection Timeout={connection.authenticationMode.connectionTimeout or 30};Authentication={connection.authenticationMode.authentication.value};"
55
+
56
+ connection_url = URL.create(
57
+ "mssql+pyodbc", query={"odbc_connect": connection_string}
58
+ )
59
+ return connection_url
43
60
  url = f"{connection.scheme.value}://"
44
61
 
45
62
  if connection.username:
46
63
  url += f"{quote_plus(connection.username)}"
47
64
  url += (
48
65
  f":{quote_plus(connection.password.get_secret_value())}"
49
- if connection
66
+ if connection.password
50
67
  else ""
51
68
  )
52
69
  url += "@"
@@ -54,12 +71,13 @@ def get_connection_url(connection: Union[AzureSQLConnection, MssqlConnection]) -
54
71
  url += f"{connection.hostPort}"
55
72
  url += f"/{quote_plus(connection.database)}" if connection.database else ""
56
73
  url += f"?driver={quote_plus(connection.driver)}"
74
+
57
75
  options = get_connection_options_dict(connection)
58
76
  if options:
59
77
  if not connection.database:
60
78
  url += "/"
61
79
  params = "&".join(
62
- f"{key}={quote_plus(value)}" for (key, value) in options.items() if value
80
+ f"{key}={quote_plus(value)}" for key, value in options.items() if value
63
81
  )
64
82
  url = f"{url}?{params}"
65
83
 
@@ -20,6 +20,7 @@ from typing import Optional
20
20
 
21
21
  from google.cloud import storage
22
22
 
23
+ from metadata.clients.azure_client import AzureClient
23
24
  from metadata.generated.schema.entity.automations.workflow import (
24
25
  Workflow as AutomationWorkflow,
25
26
  )
@@ -88,22 +89,9 @@ def _(config: GCSConfig):
88
89
 
89
90
  @get_datalake_client.register
90
91
  def _(config: AzureConfig):
91
- from azure.identity import ClientSecretCredential
92
- from azure.storage.blob import BlobServiceClient
93
92
 
94
93
  try:
95
- credentials = ClientSecretCredential(
96
- config.securityConfig.tenantId,
97
- config.securityConfig.clientId,
98
- config.securityConfig.clientSecret.get_secret_value(),
99
- )
100
-
101
- azure_client = BlobServiceClient(
102
- f"https://{config.securityConfig.accountName}.blob.core.windows.net/",
103
- credential=credentials,
104
- )
105
- return azure_client
106
-
94
+ return AzureClient(config.securityConfig).create_blob_client()
107
95
  except Exception as exc:
108
96
  raise RuntimeError(
109
97
  f"Unknown error connecting with {config.securityConfig}: {exc}."
@@ -407,7 +407,7 @@ class DatalakeSource(DatabaseServiceSource):
407
407
  schema_name = self.context.database_schema
408
408
  try:
409
409
  table_constraints = None
410
- data_frame = fetch_dataframe(
410
+ data_frame, raw_data = fetch_dataframe(
411
411
  config_source=self.config_source,
412
412
  client=self.client,
413
413
  file_fqn=DatalakeTableSchemaWrapper(
@@ -415,10 +415,11 @@ class DatalakeSource(DatabaseServiceSource):
415
415
  bucket_name=schema_name,
416
416
  file_extension=table_extension,
417
417
  ),
418
+ fetch_raw_data=True,
418
419
  )
419
420
  if data_frame:
420
421
  column_parser = DataFrameColumnParser.create(
421
- data_frame[0], table_extension
422
+ data_frame[0], table_extension, raw_data=raw_data
422
423
  )
423
424
  columns = column_parser.get_columns()
424
425
  else:
@@ -20,6 +20,7 @@ from typing import Dict, Iterable, List, Optional, Tuple
20
20
  import requests
21
21
 
22
22
  from metadata.clients.aws_client import AWSClient
23
+ from metadata.clients.azure_client import AzureClient
23
24
  from metadata.generated.schema.metadataIngestion.dbtconfig.dbtAzureConfig import (
24
25
  DbtAzureConfig,
25
26
  )
@@ -357,21 +358,8 @@ def _(config: DbtGcsConfig):
357
358
  def _(config: DbtAzureConfig):
358
359
  try:
359
360
  bucket_name, prefix = get_dbt_prefix_config(config)
360
- from azure.identity import ( # pylint: disable=import-outside-toplevel
361
- ClientSecretCredential,
362
- )
363
- from azure.storage.blob import ( # pylint: disable=import-outside-toplevel
364
- BlobServiceClient,
365
- )
366
361
 
367
- client = BlobServiceClient(
368
- f"https://{config.dbtSecurityConfig.accountName}.blob.core.windows.net/",
369
- credential=ClientSecretCredential(
370
- config.dbtSecurityConfig.tenantId,
371
- config.dbtSecurityConfig.clientId,
372
- config.dbtSecurityConfig.clientSecret.get_secret_value(),
373
- ),
374
- )
362
+ client = AzureClient(config.dbtSecurityConfig).create_blob_client()
375
363
 
376
364
  if not bucket_name:
377
365
  container_dicts = client.list_containers()
@@ -27,5 +27,6 @@ class MssqlLineageSource(MssqlQueryParserSource, LineageSource):
27
27
  OR lower(t.text) LIKE '%%merge%%'
28
28
  )
29
29
  AND lower(t.text) NOT LIKE '%%create%%procedure%%'
30
+ AND lower(t.text) NOT LIKE '%%create%%function%%'
30
31
  AND lower(t.text) NOT LIKE '%%declare%%'
31
32
  """
@@ -19,4 +19,8 @@ from metadata.ingestion.source.database.usage_source import UsageSource
19
19
  class MssqlUsageSource(MssqlQueryParserSource, UsageSource):
20
20
  sql_stmt = MSSQL_SQL_STATEMENT
21
21
 
22
- filters = "" # No filtering in the queries
22
+ filters = """
23
+ AND lower(t.text) NOT LIKE '%%create%%procedure%%'
24
+ AND lower(t.text) NOT LIKE '%%create%%function%%'
25
+ AND lower(t.text) NOT LIKE '%%declare%%'
26
+ """
@@ -16,9 +16,13 @@ from typing import Optional
16
16
 
17
17
  from sqlalchemy.engine import Engine
18
18
 
19
+ from metadata.clients.azure_client import AzureClient
19
20
  from metadata.generated.schema.entity.automations.workflow import (
20
21
  Workflow as AutomationWorkflow,
21
22
  )
23
+ from metadata.generated.schema.entity.services.connections.database.common.basicAuth import (
24
+ BasicAuth,
25
+ )
22
26
  from metadata.generated.schema.entity.services.connections.database.mysqlConnection import (
23
27
  MysqlConnection,
24
28
  )
@@ -38,6 +42,16 @@ def get_connection(connection: MysqlConnection) -> Engine:
38
42
  """
39
43
  Create connection
40
44
  """
45
+ if hasattr(connection.authType, "azureConfig"):
46
+ azure_client = AzureClient(connection.authType.azureConfig).create_client()
47
+ if not connection.authType.azureConfig.scopes:
48
+ raise ValueError(
49
+ "Azure Scopes are missing, please refer https://learn.microsoft.com/en-gb/azure/mysql/flexible-server/how-to-azure-ad#2---retrieve-microsoft-entra-access-token and fetch the resource associated with it, for e.g. https://ossrdbms-aad.database.windows.net/.default"
50
+ )
51
+ access_token_obj = azure_client.get_token(
52
+ *connection.authType.azureConfig.scopes.split(",")
53
+ )
54
+ connection.authType = BasicAuth(password=access_token_obj.token)
41
55
  if connection.sslCA or connection.sslCert or connection.sslKey:
42
56
  if not connection.connectionOptions:
43
57
  connection.connectionOptions = init_empty_connection_options()
@@ -17,9 +17,13 @@ from typing import Optional
17
17
 
18
18
  from sqlalchemy.engine import Engine
19
19
 
20
+ from metadata.clients.azure_client import AzureClient
20
21
  from metadata.generated.schema.entity.automations.workflow import (
21
22
  Workflow as AutomationWorkflow,
22
23
  )
24
+ from metadata.generated.schema.entity.services.connections.database.common.basicAuth import (
25
+ BasicAuth,
26
+ )
23
27
  from metadata.generated.schema.entity.services.connections.database.postgresConnection import (
24
28
  PostgresConnection,
25
29
  SslMode,
@@ -46,6 +50,17 @@ def get_connection(connection: PostgresConnection) -> Engine:
46
50
  """
47
51
  Create connection
48
52
  """
53
+
54
+ if hasattr(connection.authType, "azureConfig"):
55
+ azure_client = AzureClient(connection.authType.azureConfig).create_client()
56
+ if not connection.authType.azureConfig.scopes:
57
+ raise ValueError(
58
+ "Azure Scopes are missing, please refer https://learn.microsoft.com/en-gb/azure/postgresql/flexible-server/how-to-configure-sign-in-azure-ad-authentication#retrieve-the-microsoft-entra-access-token and fetch the resource associated with it, for e.g. https://ossrdbms-aad.database.windows.net/.default"
59
+ )
60
+ access_token_obj = azure_client.get_token(
61
+ *connection.authType.azureConfig.scopes.split(",")
62
+ )
63
+ connection.authType = BasicAuth(password=access_token_obj.token)
49
64
  if connection.sslMode:
50
65
  if not connection.connectionArguments:
51
66
  connection.connectionArguments = init_empty_connection_arguments()
@@ -138,7 +138,7 @@ class StoredProcedureMixin(ABC):
138
138
  return True
139
139
 
140
140
  if query_type == "INSERT" and re.search(
141
- "^.*insert.*into.*select.*$", query_text, re.IGNORECASE
141
+ "^.*insert.*into.*select.*$", query_text.replace("\n", " "), re.IGNORECASE
142
142
  ):
143
143
  return True
144
144
 
@@ -260,7 +260,7 @@ class StorageServiceSource(TopologyRunnerMixin, Source, ABC):
260
260
  metadata_entry: MetadataEntry,
261
261
  ) -> List[Column]:
262
262
  """Extract Column related metadata from s3"""
263
- data_structure_details = fetch_dataframe(
263
+ data_structure_details, raw_data = fetch_dataframe(
264
264
  config_source=config_source,
265
265
  client=client,
266
266
  file_fqn=DatalakeTableSchemaWrapper(
@@ -269,10 +269,13 @@ class StorageServiceSource(TopologyRunnerMixin, Source, ABC):
269
269
  file_extension=SupportedTypes(metadata_entry.structureFormat),
270
270
  separator=metadata_entry.separator,
271
271
  ),
272
+ fetch_raw_data=True,
272
273
  )
273
274
  columns = []
274
275
  column_parser = DataFrameColumnParser.create(
275
- data_structure_details, SupportedTypes(metadata_entry.structureFormat)
276
+ data_structure_details,
277
+ SupportedTypes(metadata_entry.structureFormat),
278
+ raw_data=raw_data,
276
279
  )
277
280
  columns = column_parser.get_columns()
278
281
  return columns
@@ -18,6 +18,8 @@ import traceback
18
18
  from enum import Enum
19
19
  from typing import List, Optional
20
20
 
21
+ from pydantic.main import ModelMetaclass
22
+
21
23
  from metadata.generated.schema.type.schema import FieldModel
22
24
  from metadata.utils.logger import ingestion_logger
23
25
 
@@ -36,20 +38,25 @@ class JsonSchemaDataTypes(Enum):
36
38
  NULL = "null"
37
39
  RECORD = "object"
38
40
  ARRAY = "array"
41
+ UNKNOWN = "unknown"
39
42
 
40
43
 
41
- def parse_json_schema(schema_text: str) -> Optional[List[FieldModel]]:
44
+ def parse_json_schema(
45
+ schema_text: str, cls: ModelMetaclass = FieldModel
46
+ ) -> Optional[List[FieldModel]]:
42
47
  """
43
48
  Method to parse the jsonschema
44
49
  """
45
50
  try:
46
51
  json_schema_data = json.loads(schema_text)
47
52
  field_models = [
48
- FieldModel(
53
+ cls(
49
54
  name=json_schema_data.get("title", "default"),
50
55
  dataType=JsonSchemaDataTypes(json_schema_data.get("type")).name,
51
56
  description=json_schema_data.get("description"),
52
- children=get_json_schema_fields(json_schema_data.get("properties")),
57
+ children=get_json_schema_fields(
58
+ json_schema_data.get("properties", {}), cls=cls
59
+ ),
53
60
  )
54
61
  ]
55
62
  return field_models
@@ -59,7 +66,9 @@ def parse_json_schema(schema_text: str) -> Optional[List[FieldModel]]:
59
66
  return None
60
67
 
61
68
 
62
- def get_json_schema_fields(properties) -> Optional[List[FieldModel]]:
69
+ def get_json_schema_fields(
70
+ properties, cls: ModelMetaclass = FieldModel
71
+ ) -> Optional[List[FieldModel]]:
63
72
  """
64
73
  Recursively convert the parsed schema into required models
65
74
  """
@@ -67,9 +76,10 @@ def get_json_schema_fields(properties) -> Optional[List[FieldModel]]:
67
76
  for key, value in properties.items():
68
77
  try:
69
78
  field_models.append(
70
- FieldModel(
71
- name=value.get("title", key),
72
- dataType=JsonSchemaDataTypes(value.get("type")).name,
79
+ cls(
80
+ name=key,
81
+ displayName=value.get("title"),
82
+ dataType=JsonSchemaDataTypes(value.get("type", "unknown")).name,
73
83
  description=value.get("description"),
74
84
  children=get_json_schema_fields(value.get("properties"))
75
85
  if value.get("type") == "object"
@@ -21,7 +21,7 @@ from pydantic import BaseModel
21
21
 
22
22
  from metadata.generated.schema.entity.classification.tag import Tag
23
23
  from metadata.pii.constants import PII, SPACY_EN_MODEL
24
- from metadata.pii.models import TagAndConfidence, TagType
24
+ from metadata.pii.models import TagAndConfidence
25
25
  from metadata.pii.ner import NEREntity
26
26
  from metadata.utils import fqn
27
27
  from metadata.utils.logger import pii_logger
@@ -119,13 +119,15 @@ class NERScanner:
119
119
 
120
120
  if entities_score:
121
121
  label, score = self.get_highest_score_label(entities_score)
122
- tag_type = NEREntity.__members__.get(label, TagType.NONSENSITIVE).value
122
+ tag_type = NEREntity.__members__.get(label)
123
+ if not tag_type:
124
+ return None
123
125
  return TagAndConfidence(
124
126
  tag_fqn=fqn.build(
125
127
  metadata=None,
126
128
  entity_type=Tag,
127
129
  classification_name=PII,
128
- tag_name=tag_type,
130
+ tag_name=tag_type.value,
129
131
  ),
130
132
  confidence=score,
131
133
  )
@@ -33,7 +33,7 @@ from metadata.generated.schema.entity.data.table import (
33
33
  TableData,
34
34
  )
35
35
  from metadata.generated.schema.entity.services.connections.connectionBasicType import (
36
- SampleDataStorageConfig,
36
+ DataStorageConfig,
37
37
  )
38
38
  from metadata.generated.schema.entity.services.connections.database.datalakeConnection import (
39
39
  DatalakeConnection,
@@ -93,7 +93,7 @@ class ProfilerInterface(ABC):
93
93
  service_connection_config: Union[DatabaseConnection, DatalakeConnection],
94
94
  ometa_client: OpenMetadata,
95
95
  entity: Table,
96
- storage_config: SampleDataStorageConfig,
96
+ storage_config: DataStorageConfig,
97
97
  profile_sample_config: Optional[ProfileSampleConfig],
98
98
  source_config: DatabaseServiceProfilerPipeline,
99
99
  sample_query: Optional[str],
@@ -248,7 +248,7 @@ class ProfilerInterface(ABC):
248
248
  DatabaseProfilerConfig,
249
249
  DatabaseAndSchemaConfig,
250
250
  ]
251
- ):
251
+ ) -> Optional[DataStorageConfig]:
252
252
  if (
253
253
  config
254
254
  and config.sampleDataStorageConfig
@@ -264,7 +264,7 @@ class ProfilerInterface(ABC):
264
264
  database_profiler_config: Optional[DatabaseProfilerConfig],
265
265
  db_service: Optional[DatabaseService],
266
266
  profiler_config: ProfilerProcessorConfig,
267
- ) -> Optional[SampleDataStorageConfig]:
267
+ ) -> Optional[DataStorageConfig]:
268
268
  """Get config for a specific entity
269
269
 
270
270
  Args: