openmetadata-ingestion 1.7.5.3__py3-none-any.whl → 1.7.6.0__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.
- metadata/generated/schema/analytics/__init__.py +1 -1
- metadata/generated/schema/analytics/basic.py +1 -1
- metadata/generated/schema/analytics/reportData.py +1 -1
- metadata/generated/schema/analytics/reportDataType/__init__.py +1 -1
- metadata/generated/schema/analytics/reportDataType/aggregatedCostAnalysisReportData.py +1 -1
- metadata/generated/schema/analytics/reportDataType/entityReportData.py +1 -1
- metadata/generated/schema/analytics/reportDataType/rawCostAnalysisReportData.py +1 -1
- metadata/generated/schema/analytics/reportDataType/webAnalyticEntityViewReportData.py +1 -1
- metadata/generated/schema/analytics/reportDataType/webAnalyticUserActivityReportData.py +1 -1
- metadata/generated/schema/analytics/webAnalyticEvent.py +1 -1
- metadata/generated/schema/analytics/webAnalyticEventData.py +1 -1
- metadata/generated/schema/analytics/webAnalyticEventType/__init__.py +1 -1
- metadata/generated/schema/analytics/webAnalyticEventType/customEvent.py +1 -1
- metadata/generated/schema/analytics/webAnalyticEventType/pageViewEvent.py +1 -1
- metadata/generated/schema/api/__init__.py +1 -1
- metadata/generated/schema/api/addGlossaryToAssetsRequest.py +1 -1
- metadata/generated/schema/api/addTagToAssetsRequest.py +1 -1
- metadata/generated/schema/api/analytics/__init__.py +1 -1
- metadata/generated/schema/api/analytics/createWebAnalyticEvent.py +1 -1
- metadata/generated/schema/api/automations/__init__.py +1 -1
- metadata/generated/schema/api/automations/createWorkflow.py +1 -1
- metadata/generated/schema/api/bulkAssets.py +1 -1
- metadata/generated/schema/api/classification/__init__.py +1 -1
- metadata/generated/schema/api/classification/createClassification.py +1 -1
- metadata/generated/schema/api/classification/createTag.py +1 -1
- metadata/generated/schema/api/classification/loadTags.py +1 -1
- metadata/generated/schema/api/createBot.py +1 -1
- metadata/generated/schema/api/createEventPublisherJob.py +1 -1
- metadata/generated/schema/api/createType.py +1 -1
- metadata/generated/schema/api/data/__init__.py +1 -1
- metadata/generated/schema/api/data/createAPICollection.py +1 -1
- metadata/generated/schema/api/data/createAPIEndpoint.py +1 -1
- metadata/generated/schema/api/data/createChart.py +1 -1
- metadata/generated/schema/api/data/createContainer.py +1 -1
- metadata/generated/schema/api/data/createCustomProperty.py +1 -1
- metadata/generated/schema/api/data/createDashboard.py +1 -1
- metadata/generated/schema/api/data/createDashboardDataModel.py +1 -1
- metadata/generated/schema/api/data/createDatabase.py +1 -1
- metadata/generated/schema/api/data/createDatabaseSchema.py +1 -1
- metadata/generated/schema/api/data/createGlossary.py +1 -1
- metadata/generated/schema/api/data/createGlossaryTerm.py +1 -1
- metadata/generated/schema/api/data/createMetric.py +1 -1
- metadata/generated/schema/api/data/createMlModel.py +1 -1
- metadata/generated/schema/api/data/createPipeline.py +1 -1
- metadata/generated/schema/api/data/createQuery.py +1 -1
- metadata/generated/schema/api/data/createQueryCostRecord.py +1 -1
- metadata/generated/schema/api/data/createSearchIndex.py +1 -1
- metadata/generated/schema/api/data/createStoredProcedure.py +1 -1
- metadata/generated/schema/api/data/createTable.py +1 -1
- metadata/generated/schema/api/data/createTableProfile.py +1 -1
- metadata/generated/schema/api/data/createTopic.py +1 -1
- metadata/generated/schema/api/data/loadGlossary.py +1 -1
- metadata/generated/schema/api/data/restoreEntity.py +1 -1
- metadata/generated/schema/api/dataInsight/__init__.py +1 -1
- metadata/generated/schema/api/dataInsight/createDataInsightChart.py +1 -1
- metadata/generated/schema/api/dataInsight/custom/__init__.py +1 -1
- metadata/generated/schema/api/dataInsight/custom/createDataInsightCustomChart.py +1 -1
- metadata/generated/schema/api/dataInsight/kpi/__init__.py +1 -1
- metadata/generated/schema/api/dataInsight/kpi/createKpiRequest.py +1 -1
- metadata/generated/schema/api/docStore/__init__.py +1 -1
- metadata/generated/schema/api/docStore/createDocument.py +1 -1
- metadata/generated/schema/api/domains/__init__.py +1 -1
- metadata/generated/schema/api/domains/createDataProduct.py +1 -1
- metadata/generated/schema/api/domains/createDomain.py +1 -1
- metadata/generated/schema/api/feed/__init__.py +1 -1
- metadata/generated/schema/api/feed/closeTask.py +1 -1
- metadata/generated/schema/api/feed/createPost.py +1 -1
- metadata/generated/schema/api/feed/createSuggestion.py +1 -1
- metadata/generated/schema/api/feed/createThread.py +1 -1
- metadata/generated/schema/api/feed/resolveTask.py +1 -1
- metadata/generated/schema/api/feed/threadCount.py +1 -1
- metadata/generated/schema/api/governance/__init__.py +1 -1
- metadata/generated/schema/api/governance/createWorkflowDefinition.py +1 -1
- metadata/generated/schema/api/governance/createWorkflowInstanceState.py +1 -1
- metadata/generated/schema/api/lineage/__init__.py +1 -1
- metadata/generated/schema/api/lineage/addLineage.py +1 -1
- metadata/generated/schema/api/lineage/esLineageData.py +1 -1
- metadata/generated/schema/api/lineage/lineageDirection.py +1 -1
- metadata/generated/schema/api/lineage/nodeInformation.py +1 -1
- metadata/generated/schema/api/lineage/searchLineageRequest.py +1 -1
- metadata/generated/schema/api/lineage/searchLineageResult.py +1 -1
- metadata/generated/schema/api/openMetadataServerVersion.py +1 -1
- metadata/generated/schema/api/policies/__init__.py +1 -1
- metadata/generated/schema/api/policies/createPolicy.py +1 -1
- metadata/generated/schema/api/search/__init__.py +1 -1
- metadata/generated/schema/api/search/previewSearchRequest.py +1 -1
- metadata/generated/schema/api/services/__init__.py +1 -1
- metadata/generated/schema/api/services/createApiService.py +1 -1
- metadata/generated/schema/api/services/createDashboardService.py +1 -1
- metadata/generated/schema/api/services/createDatabaseService.py +1 -1
- metadata/generated/schema/api/services/createMessagingService.py +1 -1
- metadata/generated/schema/api/services/createMetadataService.py +1 -1
- metadata/generated/schema/api/services/createMlModelService.py +1 -1
- metadata/generated/schema/api/services/createPipelineService.py +1 -1
- metadata/generated/schema/api/services/createSearchService.py +1 -1
- metadata/generated/schema/api/services/createStorageService.py +1 -1
- metadata/generated/schema/api/services/ingestionPipelines/__init__.py +1 -1
- metadata/generated/schema/api/services/ingestionPipelines/createIngestionPipeline.py +1 -1
- metadata/generated/schema/api/setOwner.py +1 -1
- metadata/generated/schema/api/teams/__init__.py +1 -1
- metadata/generated/schema/api/teams/createPersona.py +1 -1
- metadata/generated/schema/api/teams/createRole.py +1 -1
- metadata/generated/schema/api/teams/createTeam.py +1 -1
- metadata/generated/schema/api/teams/createUser.py +1 -1
- metadata/generated/schema/api/tests/__init__.py +1 -1
- metadata/generated/schema/api/tests/createCustomMetric.py +1 -1
- metadata/generated/schema/api/tests/createLogicalTestCases.py +1 -1
- metadata/generated/schema/api/tests/createTestCase.py +1 -1
- metadata/generated/schema/api/tests/createTestCaseResolutionStatus.py +1 -1
- metadata/generated/schema/api/tests/createTestCaseResult.py +1 -1
- metadata/generated/schema/api/tests/createTestDefinition.py +1 -1
- metadata/generated/schema/api/tests/createTestSuite.py +1 -1
- metadata/generated/schema/api/voteRequest.py +1 -1
- metadata/generated/schema/auth/__init__.py +1 -1
- metadata/generated/schema/auth/basicAuth.py +1 -1
- metadata/generated/schema/auth/basicLoginRequest.py +1 -1
- metadata/generated/schema/auth/changePasswordRequest.py +1 -1
- metadata/generated/schema/auth/createPersonalToken.py +1 -1
- metadata/generated/schema/auth/emailRequest.py +1 -1
- metadata/generated/schema/auth/emailVerificationToken.py +1 -1
- metadata/generated/schema/auth/generateToken.py +1 -1
- metadata/generated/schema/auth/jwtAuth.py +1 -1
- metadata/generated/schema/auth/loginRequest.py +1 -1
- metadata/generated/schema/auth/logoutRequest.py +1 -1
- metadata/generated/schema/auth/passwordResetRequest.py +1 -1
- metadata/generated/schema/auth/passwordResetToken.py +1 -1
- metadata/generated/schema/auth/personalAccessToken.py +1 -1
- metadata/generated/schema/auth/refreshToken.py +1 -1
- metadata/generated/schema/auth/registrationRequest.py +1 -1
- metadata/generated/schema/auth/revokePersonalToken.py +1 -1
- metadata/generated/schema/auth/revokeToken.py +1 -1
- metadata/generated/schema/auth/serviceTokenEnum.py +1 -1
- metadata/generated/schema/auth/ssoAuth.py +1 -1
- metadata/generated/schema/auth/tokenRefreshRequest.py +1 -1
- metadata/generated/schema/configuration/__init__.py +1 -1
- metadata/generated/schema/configuration/appsPrivateConfiguration.py +1 -1
- metadata/generated/schema/configuration/assetCertificationSettings.py +1 -1
- metadata/generated/schema/configuration/authConfig.py +1 -1
- metadata/generated/schema/configuration/authenticationConfiguration.py +1 -1
- metadata/generated/schema/configuration/authorizerConfiguration.py +1 -1
- metadata/generated/schema/configuration/changeEventConfiguration.py +1 -1
- metadata/generated/schema/configuration/dataQualityConfiguration.py +1 -1
- metadata/generated/schema/configuration/elasticSearchConfiguration.py +1 -1
- metadata/generated/schema/configuration/eventHandlerConfiguration.py +1 -1
- metadata/generated/schema/configuration/fernetConfiguration.py +1 -1
- metadata/generated/schema/configuration/jwtTokenConfiguration.py +1 -1
- metadata/generated/schema/configuration/kafkaEventConfiguration.py +1 -1
- metadata/generated/schema/configuration/ldapConfiguration.py +1 -1
- metadata/generated/schema/configuration/ldapTrustStoreConfig/__init__.py +1 -1
- metadata/generated/schema/configuration/ldapTrustStoreConfig/customTrustManagerConfig.py +1 -1
- metadata/generated/schema/configuration/ldapTrustStoreConfig/hostNameConfig.py +1 -1
- metadata/generated/schema/configuration/ldapTrustStoreConfig/jvmDefaultConfig.py +1 -1
- metadata/generated/schema/configuration/ldapTrustStoreConfig/trustAllConfig.py +1 -1
- metadata/generated/schema/configuration/ldapTrustStoreConfig/truststoreConfig.py +1 -1
- metadata/generated/schema/configuration/limitsConfiguration.py +1 -1
- metadata/generated/schema/configuration/lineageSettings.py +1 -1
- metadata/generated/schema/configuration/loginConfiguration.py +1 -1
- metadata/generated/schema/configuration/logoConfiguration.py +1 -1
- metadata/generated/schema/configuration/openMetadataBaseUrlConfiguration.py +1 -1
- metadata/generated/schema/configuration/opertionalConfiguration.py +1 -1
- metadata/generated/schema/configuration/opsConfig.py +1 -1
- metadata/generated/schema/configuration/pipelineServiceClientConfiguration.py +1 -1
- metadata/generated/schema/configuration/profilerConfiguration.py +1 -1
- metadata/generated/schema/configuration/searchSettings.py +1 -1
- metadata/generated/schema/configuration/slackAppConfiguration.py +1 -1
- metadata/generated/schema/configuration/taskNotificationConfiguration.py +1 -1
- metadata/generated/schema/configuration/testResultNotificationConfiguration.py +1 -1
- metadata/generated/schema/configuration/themeConfiguration.py +1 -1
- metadata/generated/schema/configuration/uiThemePreference.py +1 -1
- metadata/generated/schema/configuration/workflowSettings.py +1 -1
- metadata/generated/schema/dataInsight/__init__.py +1 -1
- metadata/generated/schema/dataInsight/custom/__init__.py +1 -1
- metadata/generated/schema/dataInsight/custom/dataInsightCustomChart.py +1 -1
- metadata/generated/schema/dataInsight/custom/dataInsightCustomChartResult.py +1 -1
- metadata/generated/schema/dataInsight/custom/dataInsightCustomChartResultList.py +1 -1
- metadata/generated/schema/dataInsight/custom/formulaHolder.py +1 -1
- metadata/generated/schema/dataInsight/custom/lineChart.py +1 -1
- metadata/generated/schema/dataInsight/custom/summaryCard.py +1 -1
- metadata/generated/schema/dataInsight/dataInsightChart.py +1 -1
- metadata/generated/schema/dataInsight/dataInsightChartResult.py +1 -1
- metadata/generated/schema/dataInsight/kpi/__init__.py +1 -1
- metadata/generated/schema/dataInsight/kpi/basic.py +1 -1
- metadata/generated/schema/dataInsight/kpi/kpi.py +1 -1
- metadata/generated/schema/dataInsight/type/__init__.py +1 -1
- metadata/generated/schema/dataInsight/type/aggregatedUnusedAssetsCount.py +1 -1
- metadata/generated/schema/dataInsight/type/aggregatedUnusedAssetsSize.py +1 -1
- metadata/generated/schema/dataInsight/type/aggregatedUsedVsUnusedAssetsCount.py +1 -1
- metadata/generated/schema/dataInsight/type/aggregatedUsedVsUnusedAssetsSize.py +1 -1
- metadata/generated/schema/dataInsight/type/dailyActiveUsers.py +1 -1
- metadata/generated/schema/dataInsight/type/mostActiveUsers.py +1 -1
- metadata/generated/schema/dataInsight/type/mostViewedEntities.py +1 -1
- metadata/generated/schema/dataInsight/type/pageViewsByEntities.py +1 -1
- metadata/generated/schema/dataInsight/type/unusedAssets.py +1 -1
- metadata/generated/schema/email/__init__.py +1 -1
- metadata/generated/schema/email/emailRequest.py +1 -1
- metadata/generated/schema/email/emailTemplate.py +1 -1
- metadata/generated/schema/email/emailTemplatePlaceholder.py +1 -1
- metadata/generated/schema/email/smtpSettings.py +1 -1
- metadata/generated/schema/email/templateValidationReponse.py +1 -1
- metadata/generated/schema/entity/__init__.py +1 -1
- metadata/generated/schema/entity/applications/__init__.py +1 -1
- metadata/generated/schema/entity/applications/app.py +1 -1
- metadata/generated/schema/entity/applications/appExtension.py +1 -1
- metadata/generated/schema/entity/applications/appRunRecord.py +1 -1
- metadata/generated/schema/entity/applications/configuration/__init__.py +1 -1
- metadata/generated/schema/entity/applications/configuration/applicationConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/__init__.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/__init__.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/addCustomProperties.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/addDataProductAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/addDescriptionAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/addDomainAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/addOwnerAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/addTagsAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/addTestCaseAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/addTierAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/lineagePropagationAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/mlTaggingAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/removeCustomPropertiesAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/removeDataProductAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/removeDescriptionAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/removeDomainAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/removeOwnerAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/removeTagsAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/removeTestCaseAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automator/removeTierAction.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/automatorAppConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/collateAIAppConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/external/slackAppTokenConfiguration.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/__init__.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/autoPilotAppConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/collateAIQualityAgentAppConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/collateAITierAgentAppConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/dataInsightsAppConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/dataInsightsReportAppConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/dataRetentionConfiguration.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/helloPipelinesConfiguration.py +1 -1
- metadata/generated/schema/entity/applications/configuration/internal/searchIndexingAppConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/private/__init__.py +1 -1
- metadata/generated/schema/entity/applications/configuration/private/external/__init__.py +1 -1
- metadata/generated/schema/entity/applications/configuration/private/external/collateAIAppPrivateConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/private/internal/__init__.py +1 -1
- metadata/generated/schema/entity/applications/configuration/private/internal/collateAITierAgentAppPrivateConfig.py +1 -1
- metadata/generated/schema/entity/applications/configuration/private/limits.py +1 -1
- metadata/generated/schema/entity/applications/createAppRequest.py +1 -1
- metadata/generated/schema/entity/applications/jobStatus.py +1 -1
- metadata/generated/schema/entity/applications/liveExecutionContext.py +1 -1
- metadata/generated/schema/entity/applications/marketplace/__init__.py +1 -1
- metadata/generated/schema/entity/applications/marketplace/appMarketPlaceDefinition.py +1 -1
- metadata/generated/schema/entity/applications/marketplace/createAppMarketPlaceDefinitionReq.py +1 -1
- metadata/generated/schema/entity/applications/scheduledExecutionContext.py +1 -1
- metadata/generated/schema/entity/automations/__init__.py +1 -1
- metadata/generated/schema/entity/automations/testServiceConnection.py +1 -1
- metadata/generated/schema/entity/automations/workflow.py +1 -1
- metadata/generated/schema/entity/bot.py +1 -1
- metadata/generated/schema/entity/classification/__init__.py +1 -1
- metadata/generated/schema/entity/classification/classification.py +1 -1
- metadata/generated/schema/entity/classification/tag.py +1 -1
- metadata/generated/schema/entity/data/__init__.py +1 -1
- metadata/generated/schema/entity/data/apiCollection.py +1 -1
- metadata/generated/schema/entity/data/apiEndpoint.py +1 -1
- metadata/generated/schema/entity/data/chart.py +1 -1
- metadata/generated/schema/entity/data/container.py +1 -1
- metadata/generated/schema/entity/data/dashboard.py +1 -1
- metadata/generated/schema/entity/data/dashboardDataModel.py +1 -1
- metadata/generated/schema/entity/data/database.py +1 -1
- metadata/generated/schema/entity/data/databaseSchema.py +1 -1
- metadata/generated/schema/entity/data/glossary.py +1 -1
- metadata/generated/schema/entity/data/glossaryTerm.py +1 -1
- metadata/generated/schema/entity/data/metric.py +1 -1
- metadata/generated/schema/entity/data/mlmodel.py +1 -1
- metadata/generated/schema/entity/data/pipeline.py +1 -1
- metadata/generated/schema/entity/data/query.py +1 -1
- metadata/generated/schema/entity/data/queryCostRecord.py +1 -1
- metadata/generated/schema/entity/data/queryCostSearchResult.py +1 -1
- metadata/generated/schema/entity/data/report.py +1 -1
- metadata/generated/schema/entity/data/searchIndex.py +1 -1
- metadata/generated/schema/entity/data/storedProcedure.py +1 -1
- metadata/generated/schema/entity/data/table.py +1 -1
- metadata/generated/schema/entity/data/topic.py +1 -1
- metadata/generated/schema/entity/docStore/__init__.py +1 -1
- metadata/generated/schema/entity/docStore/document.py +1 -1
- metadata/generated/schema/entity/domains/__init__.py +1 -1
- metadata/generated/schema/entity/domains/dataProduct.py +1 -1
- metadata/generated/schema/entity/domains/domain.py +1 -1
- metadata/generated/schema/entity/events/__init__.py +1 -1
- metadata/generated/schema/entity/events/webhook.py +1 -1
- metadata/generated/schema/entity/feed/__init__.py +1 -1
- metadata/generated/schema/entity/feed/assets.py +1 -1
- metadata/generated/schema/entity/feed/customProperty.py +1 -1
- metadata/generated/schema/entity/feed/description.py +1 -1
- metadata/generated/schema/entity/feed/domain.py +1 -1
- metadata/generated/schema/entity/feed/entityInfo.py +1 -1
- metadata/generated/schema/entity/feed/owner.py +1 -1
- metadata/generated/schema/entity/feed/suggestion.py +1 -1
- metadata/generated/schema/entity/feed/tag.py +1 -1
- metadata/generated/schema/entity/feed/testCaseResult.py +1 -1
- metadata/generated/schema/entity/feed/thread.py +1 -1
- metadata/generated/schema/entity/policies/__init__.py +1 -1
- metadata/generated/schema/entity/policies/accessControl/__init__.py +1 -1
- metadata/generated/schema/entity/policies/accessControl/resourceDescriptor.py +1 -1
- metadata/generated/schema/entity/policies/accessControl/resourcePermission.py +1 -1
- metadata/generated/schema/entity/policies/accessControl/rule.py +1 -1
- metadata/generated/schema/entity/policies/filters.py +1 -1
- metadata/generated/schema/entity/policies/policy.py +1 -1
- metadata/generated/schema/entity/services/__init__.py +1 -1
- metadata/generated/schema/entity/services/apiService.py +1 -1
- metadata/generated/schema/entity/services/connections/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/api/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/api/restConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/common/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/common/sslCertPaths.py +1 -1
- metadata/generated/schema/entity/services/connections/common/sslCertValues.py +1 -1
- metadata/generated/schema/entity/services/connections/common/sslConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/connectionBasicType.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/customDashboardConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/domoDashboardConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/lightdashConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/lookerConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/metabaseConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/microStrategyConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/modeConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/powerBIConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/powerBIReportServerConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/powerbi/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/powerbi/azureConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/powerbi/bucketDetails.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/powerbi/gcsConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/powerbi/s3Config.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/qlikCloudConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/qlikSenseConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/quickSightConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/redashConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/sigmaConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/supersetConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/dashboard/tableauConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/database/athenaConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/azureSQLConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/bigQueryConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/bigTableConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/cassandra/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/database/cassandra/cloudConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/database/cassandraConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/clickhouseConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/cockroachConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/common/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/database/common/azureConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/database/common/basicAuth.py +1 -1
- metadata/generated/schema/entity/services/connections/database/common/iamAuthConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/database/common/jwtAuth.py +1 -1
- metadata/generated/schema/entity/services/connections/database/common/noConfigAuthenticationTypes.py +1 -1
- metadata/generated/schema/entity/services/connections/database/couchbaseConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/customDatabaseConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/databricksConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/datalake/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/database/datalake/azureConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/database/datalake/gcsConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/database/datalake/s3Config.py +1 -1
- metadata/generated/schema/entity/services/connections/database/datalakeConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/db2Connection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/deltaLakeConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/deltalake/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/database/deltalake/metastoreConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/database/deltalake/storageConfig.py +1 -1
- metadata/generated/schema/entity/services/connections/database/domoDatabaseConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/dorisConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/druidConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/dynamoDBConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/exasolConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/glueConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/greenplumConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/hiveConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/iceberg/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/database/iceberg/dynamoDbCatalogConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/iceberg/glueCatalogConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/iceberg/hiveCatalogConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/iceberg/icebergCatalog.py +1 -1
- metadata/generated/schema/entity/services/connections/database/iceberg/icebergFileSystem.py +1 -1
- metadata/generated/schema/entity/services/connections/database/iceberg/restCatalogConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/icebergConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/impalaConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/mariaDBConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/mongoDBConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/mssqlConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/mysqlConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/oracleConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/pinotDBConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/postgresConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/prestoConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/redshiftConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/salesforceConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/sapErpConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/sapHana/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/database/sapHana/sapHanaHDBConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/sapHana/sapHanaSQLConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/sapHanaConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/sasConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/singleStoreConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/snowflakeConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/sqliteConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/synapseConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/teradataConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/trinoConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/unityCatalogConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/database/verticaConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/messaging/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/messaging/customMessagingConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/messaging/kafkaConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/messaging/kinesisConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/messaging/pulsarConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/messaging/redpandaConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/messaging/saslMechanismType.py +1 -1
- metadata/generated/schema/entity/services/connections/metadata/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/metadata/alationConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/metadata/alationSinkConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/metadata/amundsenConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/metadata/atlasConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/metadata/metadataESConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/metadata/openMetadataConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/mlmodel/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/mlmodel/customMlModelConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/mlmodel/mlflowConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/mlmodel/sageMakerConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/mlmodel/sklearnConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/mlmodel/vertexaiConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/airbyteConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/airflowConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/backendConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/customPipelineConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/dagsterConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/databricksPipelineConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/datafactoryConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/dbtCloudConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/domoPipelineConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/fivetranConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/flinkConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/gluePipelineConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/kafkaConnectConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/matillion/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/matillion/matillionETL.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/matillionConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/nifi/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/nifi/basicAuth.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/nifi/clientCertificateAuth.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/nifiConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/openLineageConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/sparkConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/splineConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/ssisConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/stitchConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/pipeline/wherescapeConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/search/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/search/customSearchConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/search/elasticSearch/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/search/elasticSearch/apiAuth.py +1 -1
- metadata/generated/schema/entity/services/connections/search/elasticSearch/basicAuth.py +1 -1
- metadata/generated/schema/entity/services/connections/search/elasticSearchConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/search/openSearchConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/serviceConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/storage/__init__.py +1 -1
- metadata/generated/schema/entity/services/connections/storage/adlsConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/storage/customStorageConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/storage/gcsConnection.py +1 -1
- metadata/generated/schema/entity/services/connections/storage/s3Connection.py +1 -1
- metadata/generated/schema/entity/services/connections/testConnectionDefinition.py +1 -1
- metadata/generated/schema/entity/services/connections/testConnectionResult.py +1 -1
- metadata/generated/schema/entity/services/dashboardService.py +1 -1
- metadata/generated/schema/entity/services/databaseService.py +1 -1
- metadata/generated/schema/entity/services/ingestionPipelines/__init__.py +1 -1
- metadata/generated/schema/entity/services/ingestionPipelines/ingestionPipeline.py +1 -1
- metadata/generated/schema/entity/services/ingestionPipelines/pipelineServiceClientResponse.py +1 -1
- metadata/generated/schema/entity/services/ingestionPipelines/reverseIngestionResponse.py +1 -1
- metadata/generated/schema/entity/services/ingestionPipelines/status.py +1 -1
- metadata/generated/schema/entity/services/messagingService.py +1 -1
- metadata/generated/schema/entity/services/metadataService.py +1 -1
- metadata/generated/schema/entity/services/mlmodelService.py +1 -1
- metadata/generated/schema/entity/services/pipelineService.py +1 -1
- metadata/generated/schema/entity/services/searchService.py +1 -1
- metadata/generated/schema/entity/services/serviceType.py +1 -1
- metadata/generated/schema/entity/services/storageService.py +1 -1
- metadata/generated/schema/entity/teams/__init__.py +1 -1
- metadata/generated/schema/entity/teams/persona.py +1 -1
- metadata/generated/schema/entity/teams/role.py +1 -1
- metadata/generated/schema/entity/teams/team.py +1 -1
- metadata/generated/schema/entity/teams/teamHierarchy.py +1 -1
- metadata/generated/schema/entity/teams/user.py +1 -1
- metadata/generated/schema/entity/type.py +1 -1
- metadata/generated/schema/entity/utils/__init__.py +1 -1
- metadata/generated/schema/entity/utils/entitiesCount.py +1 -1
- metadata/generated/schema/entity/utils/servicesCount.py +1 -1
- metadata/generated/schema/entity/utils/supersetApiConnection.py +1 -1
- metadata/generated/schema/events/__init__.py +1 -1
- metadata/generated/schema/events/alertMetrics.py +1 -1
- metadata/generated/schema/events/api/__init__.py +1 -1
- metadata/generated/schema/events/api/createEventSubscription.py +1 -1
- metadata/generated/schema/events/api/eventSubscriptionDiagnosticInfo.py +1 -1
- metadata/generated/schema/events/api/eventsRecord.py +1 -1
- metadata/generated/schema/events/api/testEventSubscriptionDestination.py +1 -1
- metadata/generated/schema/events/api/typedEvent.py +1 -1
- metadata/generated/schema/events/emailAlertConfig.py +1 -1
- metadata/generated/schema/events/eventFilterRule.py +1 -1
- metadata/generated/schema/events/eventSubscription.py +1 -1
- metadata/generated/schema/events/eventSubscriptionOffset.py +1 -1
- metadata/generated/schema/events/failedEvent.py +1 -1
- metadata/generated/schema/events/failedEventResponse.py +1 -1
- metadata/generated/schema/events/filterResourceDescriptor.py +1 -1
- metadata/generated/schema/events/statusContext.py +1 -1
- metadata/generated/schema/events/subscriptionResourceDescriptor.py +1 -1
- metadata/generated/schema/events/subscriptionStatus.py +1 -1
- metadata/generated/schema/events/testDestinationStatus.py +1 -1
- metadata/generated/schema/governance/workflows/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/edge.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodeSubType.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodeType.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/automatedTask/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/automatedTask/checkEntityAttributesTask.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/automatedTask/createAndRunIngestionPipelineTask.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/automatedTask/runAppTask.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/automatedTask/setEntityCertificationTask.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/automatedTask/setGlossaryTermStatusTask.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/endEvent/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/endEvent/endEvent.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/gateway/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/gateway/parallelGateway.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/startEvent/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/startEvent/startEvent.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/userTask/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/nodes/userTask/userApprovalTask.py +1 -1
- metadata/generated/schema/governance/workflows/elements/triggers/__init__.py +1 -1
- metadata/generated/schema/governance/workflows/elements/triggers/eventBasedEntityTrigger.py +1 -1
- metadata/generated/schema/governance/workflows/elements/triggers/noOpTrigger.py +1 -1
- metadata/generated/schema/governance/workflows/elements/triggers/periodicBatchEntityTrigger.py +1 -1
- metadata/generated/schema/governance/workflows/workflowDefinition.py +1 -1
- metadata/generated/schema/governance/workflows/workflowInstance.py +1 -1
- metadata/generated/schema/governance/workflows/workflowInstanceState.py +1 -1
- metadata/generated/schema/jobs/__init__.py +1 -1
- metadata/generated/schema/jobs/backgroundJob.py +1 -1
- metadata/generated/schema/jobs/enumCleanupArgs.py +1 -1
- metadata/generated/schema/metadataIngestion/__init__.py +1 -1
- metadata/generated/schema/metadataIngestion/apiServiceMetadataPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/application.py +1 -1
- metadata/generated/schema/metadataIngestion/applicationPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/dashboardServiceMetadataPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/dataInsightPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/databaseServiceAutoClassificationPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/databaseServiceMetadataPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/databaseServiceProfilerPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/databaseServiceQueryLineagePipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/databaseServiceQueryUsagePipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtconfig/__init__.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtconfig/dbtAzureConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtconfig/dbtBucketDetails.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtconfig/dbtCloudConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtconfig/dbtGCSConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtconfig/dbtHttpConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtconfig/dbtLocalConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/dbtconfig/dbtS3Config.py +1 -1
- metadata/generated/schema/metadataIngestion/messagingServiceMetadataPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/metadataToElasticSearchPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/mlmodelServiceMetadataPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/pipelineServiceMetadataPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/reverseIngestionPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/reverseingestionconfig/__init__.py +1 -1
- metadata/generated/schema/metadataIngestion/reverseingestionconfig/descriptionConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/reverseingestionconfig/ownerConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/reverseingestionconfig/tagsConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/searchServiceMetadataPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/__init__.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/containerMetadataConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/manifestMetadataConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/storageBucketDetails.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/storageMetadataADLSConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/storageMetadataGCSConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/storageMetadataHttpConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/storageMetadataLocalConfig.py +1 -1
- metadata/generated/schema/metadataIngestion/storage/storageMetadataS3Config.py +1 -1
- metadata/generated/schema/metadataIngestion/storageServiceMetadataPipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/testSuitePipeline.py +1 -1
- metadata/generated/schema/metadataIngestion/workflow.py +1 -1
- metadata/generated/schema/monitoring/__init__.py +1 -1
- metadata/generated/schema/monitoring/eventMonitorProvider.py +1 -1
- metadata/generated/schema/search/__init__.py +1 -1
- metadata/generated/schema/search/aggregationRequest.py +1 -1
- metadata/generated/schema/search/searchRequest.py +1 -1
- metadata/generated/schema/security/__init__.py +1 -1
- metadata/generated/schema/security/client/__init__.py +1 -1
- metadata/generated/schema/security/client/auth0SSOClientConfig.py +1 -1
- metadata/generated/schema/security/client/azureSSOClientConfig.py +1 -1
- metadata/generated/schema/security/client/customOidcSSOClientConfig.py +1 -1
- metadata/generated/schema/security/client/googleSSOClientConfig.py +1 -1
- metadata/generated/schema/security/client/oidcClientConfig.py +1 -1
- metadata/generated/schema/security/client/oktaSSOClientConfig.py +1 -1
- metadata/generated/schema/security/client/openMetadataJWTClientConfig.py +1 -1
- metadata/generated/schema/security/client/samlSSOClientConfig.py +1 -1
- metadata/generated/schema/security/credentials/__init__.py +1 -1
- metadata/generated/schema/security/credentials/accessTokenAuth.py +1 -1
- metadata/generated/schema/security/credentials/apiAccessTokenAuth.py +1 -1
- metadata/generated/schema/security/credentials/awsCredentials.py +1 -1
- metadata/generated/schema/security/credentials/azureCredentials.py +1 -1
- metadata/generated/schema/security/credentials/basicAuth.py +1 -1
- metadata/generated/schema/security/credentials/bitbucketCredentials.py +1 -1
- metadata/generated/schema/security/credentials/gcpCredentials.py +1 -1
- metadata/generated/schema/security/credentials/gcpExternalAccount.py +1 -1
- metadata/generated/schema/security/credentials/gcpValues.py +1 -1
- metadata/generated/schema/security/credentials/gitCredentials.py +1 -1
- metadata/generated/schema/security/credentials/githubCredentials.py +1 -1
- metadata/generated/schema/security/credentials/gitlabCredentials.py +1 -1
- metadata/generated/schema/security/sasl/__init__.py +1 -1
- metadata/generated/schema/security/sasl/saslClientConfig.py +1 -1
- metadata/generated/schema/security/secrets/__init__.py +1 -1
- metadata/generated/schema/security/secrets/secretsManagerClientLoader.py +1 -1
- metadata/generated/schema/security/secrets/secretsManagerConfiguration.py +1 -1
- metadata/generated/schema/security/secrets/secretsManagerProvider.py +1 -1
- metadata/generated/schema/security/securityConfiguration.py +1 -1
- metadata/generated/schema/security/ssl/__init__.py +1 -1
- metadata/generated/schema/security/ssl/validateSSLClientConfig.py +1 -1
- metadata/generated/schema/security/ssl/verifySSLConfig.py +1 -1
- metadata/generated/schema/settings/__init__.py +1 -1
- metadata/generated/schema/settings/settings.py +1 -1
- metadata/generated/schema/system/__init__.py +1 -1
- metadata/generated/schema/system/entityError.py +1 -1
- metadata/generated/schema/system/eventPublisherJob.py +1 -1
- metadata/generated/schema/system/indexingError.py +1 -1
- metadata/generated/schema/system/limitsResponse.py +1 -1
- metadata/generated/schema/system/ui/__init__.py +1 -1
- metadata/generated/schema/system/ui/knowledgePanel.py +1 -1
- metadata/generated/schema/system/ui/navigationItem.py +1 -1
- metadata/generated/schema/system/ui/page.py +1 -1
- metadata/generated/schema/system/ui/tab.py +1 -1
- metadata/generated/schema/system/ui/uiCustomization.py +1 -1
- metadata/generated/schema/system/validationResponse.py +1 -1
- metadata/generated/schema/tests/__init__.py +1 -1
- metadata/generated/schema/tests/assigned.py +1 -1
- metadata/generated/schema/tests/basic.py +20 -20
- metadata/generated/schema/tests/customMetric.py +1 -1
- metadata/generated/schema/tests/dataQualityReport.py +1 -1
- metadata/generated/schema/tests/resolved.py +1 -1
- metadata/generated/schema/tests/testCase.py +1 -1
- metadata/generated/schema/tests/testCaseResolutionStatus.py +1 -1
- metadata/generated/schema/tests/testDefinition.py +1 -1
- metadata/generated/schema/tests/testSuite.py +1 -1
- metadata/generated/schema/type/__init__.py +1 -1
- metadata/generated/schema/type/apiSchema.py +1 -1
- metadata/generated/schema/type/assetCertification.py +1 -1
- metadata/generated/schema/type/auditLog.py +1 -1
- metadata/generated/schema/type/basic.py +1 -1
- metadata/generated/schema/type/bulkOperationResult.py +1 -1
- metadata/generated/schema/type/changeEvent.py +1 -1
- metadata/generated/schema/type/changeEventType.py +1 -1
- metadata/generated/schema/type/changeSummaryMap.py +1 -1
- metadata/generated/schema/type/collectionDescriptor.py +1 -1
- metadata/generated/schema/type/csvDocumentation.py +1 -1
- metadata/generated/schema/type/csvErrorType.py +1 -1
- metadata/generated/schema/type/csvFile.py +1 -1
- metadata/generated/schema/type/csvImportResult.py +1 -1
- metadata/generated/schema/type/customProperties/__init__.py +1 -1
- metadata/generated/schema/type/customProperties/complexTypes.py +1 -1
- metadata/generated/schema/type/customProperties/enumConfig.py +1 -1
- metadata/generated/schema/type/customProperties/tableConfig.py +1 -1
- metadata/generated/schema/type/customProperty.py +1 -1
- metadata/generated/schema/type/dailyCount.py +1 -1
- metadata/generated/schema/type/databaseConnectionConfig.py +1 -1
- metadata/generated/schema/type/entityHierarchy.py +1 -1
- metadata/generated/schema/type/entityHistory.py +1 -1
- metadata/generated/schema/type/entityLineage.py +1 -1
- metadata/generated/schema/type/entityReference.py +1 -1
- metadata/generated/schema/type/entityReferenceList.py +1 -1
- metadata/generated/schema/type/entityRelationship.py +1 -1
- metadata/generated/schema/type/entityUsage.py +1 -1
- metadata/generated/schema/type/filterPattern.py +1 -1
- metadata/generated/schema/type/function.py +1 -1
- metadata/generated/schema/type/include.py +1 -1
- metadata/generated/schema/type/jdbcConnection.py +1 -1
- metadata/generated/schema/type/lifeCycle.py +1 -1
- metadata/generated/schema/type/paging.py +1 -1
- metadata/generated/schema/type/profile.py +1 -1
- metadata/generated/schema/type/queryParserData.py +1 -1
- metadata/generated/schema/type/reaction.py +1 -1
- metadata/generated/schema/type/schedule.py +1 -1
- metadata/generated/schema/type/schema.py +1 -1
- metadata/generated/schema/type/tableQuery.py +1 -1
- metadata/generated/schema/type/tableUsageCount.py +1 -1
- metadata/generated/schema/type/tagLabel.py +1 -1
- metadata/generated/schema/type/usageDetails.py +1 -1
- metadata/generated/schema/type/usageRequest.py +1 -1
- metadata/generated/schema/type/votes.py +1 -1
- metadata/ingestion/models/patch_request.py +36 -4
- metadata/ingestion/ometa/mixins/patch_mixin.py +98 -40
- metadata/readers/dataframe/base.py +2 -0
- metadata/readers/dataframe/parquet.py +202 -15
- {openmetadata_ingestion-1.7.5.3.dist-info → openmetadata_ingestion-1.7.6.0.dist-info}/METADATA +532 -532
- {openmetadata_ingestion-1.7.5.3.dist-info → openmetadata_ingestion-1.7.6.0.dist-info}/RECORD +702 -702
- {openmetadata_ingestion-1.7.5.3.dist-info → openmetadata_ingestion-1.7.6.0.dist-info}/LICENSE +0 -0
- {openmetadata_ingestion-1.7.5.3.dist-info → openmetadata_ingestion-1.7.6.0.dist-info}/WHEEL +0 -0
- {openmetadata_ingestion-1.7.5.3.dist-info → openmetadata_ingestion-1.7.6.0.dist-info}/entry_points.txt +0 -0
- {openmetadata_ingestion-1.7.5.3.dist-info → openmetadata_ingestion-1.7.6.0.dist-info}/top_level.txt +0 -0
|
@@ -342,6 +342,7 @@ def build_patch(
|
|
|
342
342
|
array_entity_fields: Optional[List] = None,
|
|
343
343
|
remove_change_description: bool = True,
|
|
344
344
|
override_metadata: Optional[bool] = False,
|
|
345
|
+
skip_on_failure: Optional[bool] = True,
|
|
345
346
|
) -> Optional[jsonpatch.JsonPatch]:
|
|
346
347
|
"""
|
|
347
348
|
Given an Entity type and Source entity and Destination entity,
|
|
@@ -352,6 +353,10 @@ def build_patch(
|
|
|
352
353
|
destination: payload with changes applied to the source.
|
|
353
354
|
allowed_fields: List of field names to filter from source and destination models
|
|
354
355
|
restrict_update_fields: List of field names which will only support add operation
|
|
356
|
+
array_entity_fields: List of array fields to sort for consistent patching
|
|
357
|
+
remove_change_description: Whether to remove change description from entities
|
|
358
|
+
override_metadata: Whether to override existing metadata fields
|
|
359
|
+
skip_on_failure: Whether to skip the patch operation on failure (default: True)
|
|
355
360
|
|
|
356
361
|
Returns
|
|
357
362
|
Updated Entity
|
|
@@ -421,10 +426,37 @@ def build_patch(
|
|
|
421
426
|
patch.patch = updated_operations
|
|
422
427
|
|
|
423
428
|
return patch
|
|
424
|
-
except Exception:
|
|
429
|
+
except Exception as exc:
|
|
425
430
|
logger.debug(traceback.format_exc())
|
|
426
|
-
|
|
427
|
-
|
|
431
|
+
if skip_on_failure:
|
|
432
|
+
entity_info = ""
|
|
433
|
+
try:
|
|
434
|
+
if hasattr(source, "fullyQualifiedName"):
|
|
435
|
+
entity_info = f" for '{source.fullyQualifiedName.root}'"
|
|
436
|
+
elif hasattr(source, "name"):
|
|
437
|
+
entity_info = f" for '{source.name.root}'"
|
|
438
|
+
except Exception:
|
|
439
|
+
pass
|
|
440
|
+
|
|
441
|
+
logger.warning(
|
|
442
|
+
f"Failed to build patch{entity_info}. The patch generation was skipped. "
|
|
443
|
+
f"Reason: {exc}"
|
|
444
|
+
)
|
|
445
|
+
return None
|
|
446
|
+
else:
|
|
447
|
+
entity_info = ""
|
|
448
|
+
try:
|
|
449
|
+
if hasattr(source, "fullyQualifiedName"):
|
|
450
|
+
entity_info = f" for '{source.fullyQualifiedName.root}'"
|
|
451
|
+
elif hasattr(source, "name"):
|
|
452
|
+
entity_info = f" for '{source.name.root}'"
|
|
453
|
+
except Exception:
|
|
454
|
+
pass
|
|
455
|
+
|
|
456
|
+
raise RuntimeError(
|
|
457
|
+
f"Failed to build patch{entity_info}. The patch generation failed. "
|
|
458
|
+
f"Set 'skip_on_failure=True' to skip failed patch operations. Error: {exc}"
|
|
459
|
+
) from exc
|
|
428
460
|
|
|
429
461
|
|
|
430
462
|
def _get_attribute_name(attr: T) -> str:
|
|
@@ -534,7 +566,7 @@ def _remove_change_description(entity: T) -> T:
|
|
|
534
566
|
We never want to patch that, and we won't have that information
|
|
535
567
|
from the source. It's fully handled in the server.
|
|
536
568
|
"""
|
|
537
|
-
if getattr(entity, "changeDescription"):
|
|
569
|
+
if hasattr(entity, "changeDescription") and getattr(entity, "changeDescription"):
|
|
538
570
|
entity.changeDescription = None
|
|
539
571
|
|
|
540
572
|
return entity
|
|
@@ -124,6 +124,7 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
124
124
|
restrict_update_fields: Optional[List] = None,
|
|
125
125
|
array_entity_fields: Optional[List] = None,
|
|
126
126
|
override_metadata: Optional[bool] = False,
|
|
127
|
+
skip_on_failure: Optional[bool] = True,
|
|
127
128
|
) -> Optional[T]:
|
|
128
129
|
"""
|
|
129
130
|
Given an Entity type and Source entity and Destination entity,
|
|
@@ -135,6 +136,9 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
135
136
|
destination: payload with changes applied to the source.
|
|
136
137
|
allowed_fields: List of field names to filter from source and destination models
|
|
137
138
|
restrict_update_fields: List of field names which will only support add operation
|
|
139
|
+
array_entity_fields: List of array fields to sort for consistent patching
|
|
140
|
+
override_metadata: Whether to override existing metadata fields
|
|
141
|
+
skip_on_failure: Whether to skip the patch operation on failure (default: True)
|
|
138
142
|
|
|
139
143
|
Returns
|
|
140
144
|
Updated Entity
|
|
@@ -147,6 +151,7 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
147
151
|
restrict_update_fields=restrict_update_fields,
|
|
148
152
|
array_entity_fields=array_entity_fields,
|
|
149
153
|
override_metadata=override_metadata,
|
|
154
|
+
skip_on_failure=skip_on_failure,
|
|
150
155
|
)
|
|
151
156
|
|
|
152
157
|
if not patch:
|
|
@@ -160,9 +165,19 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
160
165
|
|
|
161
166
|
except Exception as exc:
|
|
162
167
|
logger.debug(traceback.format_exc())
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
168
|
+
if skip_on_failure:
|
|
169
|
+
entity_name = get_log_name(source)
|
|
170
|
+
logger.warning(
|
|
171
|
+
f"Failed to update {entity_name}. The patch operation was skipped. "
|
|
172
|
+
f"Reason: {exc}"
|
|
173
|
+
)
|
|
174
|
+
return None
|
|
175
|
+
else:
|
|
176
|
+
entity_name = get_log_name(source)
|
|
177
|
+
raise RuntimeError(
|
|
178
|
+
f"Failed to update {entity_name}. The patch operation failed. "
|
|
179
|
+
f"Set 'skip_on_failure=True' to skip failed patches. Error: {exc}"
|
|
180
|
+
) from exc
|
|
166
181
|
|
|
167
182
|
def patch_description(
|
|
168
183
|
self,
|
|
@@ -170,6 +185,7 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
170
185
|
source: T,
|
|
171
186
|
description: str,
|
|
172
187
|
force: bool = False,
|
|
188
|
+
skip_on_failure: bool = True,
|
|
173
189
|
) -> Optional[T]:
|
|
174
190
|
"""
|
|
175
191
|
Given an Entity type and ID, JSON PATCH the description.
|
|
@@ -180,33 +196,51 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
180
196
|
description: new description to add
|
|
181
197
|
force: if True, we will patch any existing description. Otherwise, we will maintain
|
|
182
198
|
the existing data.
|
|
199
|
+
skip_on_failure: if True, return None on failure instead of raising exception
|
|
183
200
|
Returns
|
|
184
201
|
Updated Entity
|
|
185
202
|
"""
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
203
|
+
try:
|
|
204
|
+
if isinstance(source, TestCase):
|
|
205
|
+
instance: Optional[T] = self._fetch_entity_if_exists(
|
|
206
|
+
entity=entity,
|
|
207
|
+
entity_id=source.id,
|
|
208
|
+
fields=["testDefinition", "testSuite"],
|
|
209
|
+
)
|
|
210
|
+
else:
|
|
211
|
+
instance: Optional[T] = self._fetch_entity_if_exists(
|
|
212
|
+
entity=entity, entity_id=source.id
|
|
213
|
+
)
|
|
196
214
|
|
|
197
|
-
|
|
198
|
-
|
|
215
|
+
if not instance:
|
|
216
|
+
return None
|
|
199
217
|
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
218
|
+
if instance.description and not force:
|
|
219
|
+
# If the description is already present and force is not passed,
|
|
220
|
+
# description will not be overridden
|
|
221
|
+
return None
|
|
204
222
|
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
223
|
+
# https://docs.pydantic.dev/latest/usage/exporting_models/#modelcopy
|
|
224
|
+
destination = source.model_copy(deep=True)
|
|
225
|
+
destination.description = Markdown(description)
|
|
208
226
|
|
|
209
|
-
|
|
227
|
+
return self.patch(
|
|
228
|
+
entity=entity,
|
|
229
|
+
source=source,
|
|
230
|
+
destination=destination,
|
|
231
|
+
skip_on_failure=skip_on_failure,
|
|
232
|
+
)
|
|
233
|
+
except Exception as exc:
|
|
234
|
+
if skip_on_failure:
|
|
235
|
+
logger.debug(traceback.format_exc())
|
|
236
|
+
entity_name = get_log_name(source)
|
|
237
|
+
logger.warning(
|
|
238
|
+
f"Failed to patch description for {entity_name}. The patch operation was skipped. "
|
|
239
|
+
f"Reason: {exc}"
|
|
240
|
+
)
|
|
241
|
+
return None
|
|
242
|
+
else:
|
|
243
|
+
raise
|
|
210
244
|
|
|
211
245
|
def patch_table_constraints(
|
|
212
246
|
self,
|
|
@@ -275,6 +309,7 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
275
309
|
operation: Union[
|
|
276
310
|
PatchOperation.ADD, PatchOperation.REMOVE
|
|
277
311
|
] = PatchOperation.ADD,
|
|
312
|
+
skip_on_failure: bool = True,
|
|
278
313
|
) -> Optional[T]:
|
|
279
314
|
"""
|
|
280
315
|
Given an Entity type and ID, JSON PATCH the tag.
|
|
@@ -284,29 +319,47 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
284
319
|
source: Source entity object
|
|
285
320
|
tag_label: TagLabel to add or remove
|
|
286
321
|
operation: Patch Operation to add or remove the tag.
|
|
322
|
+
skip_on_failure: if True, return None on failure instead of raising exception
|
|
287
323
|
Returns
|
|
288
324
|
Updated Entity
|
|
289
325
|
"""
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
326
|
+
try:
|
|
327
|
+
instance: Optional[T] = self._fetch_entity_if_exists(
|
|
328
|
+
entity=entity, entity_id=source.id, fields=["tags"]
|
|
329
|
+
)
|
|
330
|
+
if not instance:
|
|
331
|
+
return None
|
|
295
332
|
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
333
|
+
# Initialize empty tag list or the last updated tags
|
|
334
|
+
source.tags = instance.tags or []
|
|
335
|
+
destination = source.model_copy(deep=True)
|
|
299
336
|
|
|
300
|
-
|
|
337
|
+
tag_fqns = {label.tagFQN.root for label in tag_labels}
|
|
301
338
|
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
339
|
+
if operation == PatchOperation.REMOVE:
|
|
340
|
+
for tag in destination.tags:
|
|
341
|
+
if tag.tagFQN.root in tag_fqns:
|
|
342
|
+
destination.tags.remove(tag)
|
|
343
|
+
else:
|
|
344
|
+
destination.tags.extend(tag_labels)
|
|
308
345
|
|
|
309
|
-
|
|
346
|
+
return self.patch(
|
|
347
|
+
entity=entity,
|
|
348
|
+
source=source,
|
|
349
|
+
destination=destination,
|
|
350
|
+
skip_on_failure=skip_on_failure,
|
|
351
|
+
)
|
|
352
|
+
except Exception as exc:
|
|
353
|
+
if skip_on_failure:
|
|
354
|
+
logger.debug(traceback.format_exc())
|
|
355
|
+
entity_name = get_log_name(source)
|
|
356
|
+
logger.warning(
|
|
357
|
+
f"Failed to patch tags for {entity_name}. The patch operation was skipped. "
|
|
358
|
+
f"Reason: {exc}"
|
|
359
|
+
)
|
|
360
|
+
return None
|
|
361
|
+
else:
|
|
362
|
+
raise
|
|
310
363
|
|
|
311
364
|
def patch_tag(
|
|
312
365
|
self,
|
|
@@ -316,11 +369,16 @@ class OMetaPatchMixin(OMetaPatchMixinBase):
|
|
|
316
369
|
operation: Union[
|
|
317
370
|
PatchOperation.ADD, PatchOperation.REMOVE
|
|
318
371
|
] = PatchOperation.ADD,
|
|
372
|
+
skip_on_failure: bool = True,
|
|
319
373
|
) -> Optional[T]:
|
|
320
374
|
"""Will be deprecated in 1.3"""
|
|
321
375
|
logger.warning("patch_tag will be deprecated in 1.3. Use `patch_tags` instead.")
|
|
322
376
|
return self.patch_tags(
|
|
323
|
-
entity=entity,
|
|
377
|
+
entity=entity,
|
|
378
|
+
source=source,
|
|
379
|
+
tag_labels=[tag_label],
|
|
380
|
+
operation=operation,
|
|
381
|
+
skip_on_failure=skip_on_failure,
|
|
324
382
|
)
|
|
325
383
|
|
|
326
384
|
def patch_owner(
|
|
@@ -22,6 +22,8 @@ from metadata.readers.file.config_source_factory import get_reader
|
|
|
22
22
|
from metadata.readers.models import ConfigSource
|
|
23
23
|
from metadata.utils.logger import ingestion_logger
|
|
24
24
|
|
|
25
|
+
MAX_FILE_SIZE_FOR_PREVIEW = 50 * 1024 * 1024 # 50MB
|
|
26
|
+
|
|
25
27
|
logger = ingestion_logger()
|
|
26
28
|
|
|
27
29
|
|
|
@@ -14,6 +14,8 @@ Generic Delimiter-Separated-Values implementation
|
|
|
14
14
|
"""
|
|
15
15
|
from functools import singledispatchmethod
|
|
16
16
|
|
|
17
|
+
from pyarrow.parquet import ParquetFile
|
|
18
|
+
|
|
17
19
|
from metadata.generated.schema.entity.services.connections.database.datalake.azureConfig import (
|
|
18
20
|
AzureConfig,
|
|
19
21
|
)
|
|
@@ -26,11 +28,18 @@ from metadata.generated.schema.entity.services.connections.database.datalake.s3C
|
|
|
26
28
|
from metadata.generated.schema.entity.services.connections.database.datalakeConnection import (
|
|
27
29
|
LocalConfig,
|
|
28
30
|
)
|
|
29
|
-
from metadata.readers.dataframe.base import
|
|
31
|
+
from metadata.readers.dataframe.base import (
|
|
32
|
+
MAX_FILE_SIZE_FOR_PREVIEW,
|
|
33
|
+
DataFrameReader,
|
|
34
|
+
FileFormatException,
|
|
35
|
+
)
|
|
30
36
|
from metadata.readers.dataframe.common import dataframe_to_chunks
|
|
31
37
|
from metadata.readers.dataframe.models import DatalakeColumnWrapper
|
|
32
38
|
from metadata.readers.file.adls import AZURE_PATH, return_azure_storage_options
|
|
33
39
|
from metadata.readers.models import ConfigSource
|
|
40
|
+
from metadata.utils.logger import ingestion_logger
|
|
41
|
+
|
|
42
|
+
logger = ingestion_logger()
|
|
34
43
|
|
|
35
44
|
|
|
36
45
|
class ParquetDataFrameReader(DataFrameReader):
|
|
@@ -39,6 +48,90 @@ class ParquetDataFrameReader(DataFrameReader):
|
|
|
39
48
|
from any source based on its init client.
|
|
40
49
|
"""
|
|
41
50
|
|
|
51
|
+
def _read_parquet_in_batches(
|
|
52
|
+
self, parquet_file: ParquetFile, batch_size: int = 10000
|
|
53
|
+
):
|
|
54
|
+
"""
|
|
55
|
+
Read a large parquet file in batches to avoid memory issues.
|
|
56
|
+
Includes multiple fallback strategies for older PyArrow versions.
|
|
57
|
+
|
|
58
|
+
Args:
|
|
59
|
+
parquet_file: PyArrow ParquetFile or similar object
|
|
60
|
+
batch_size: Number of rows to read per batch
|
|
61
|
+
|
|
62
|
+
Returns:
|
|
63
|
+
List of DataFrame chunks
|
|
64
|
+
"""
|
|
65
|
+
chunks = []
|
|
66
|
+
batch_count = 0
|
|
67
|
+
|
|
68
|
+
try:
|
|
69
|
+
# Method 1: iter_batches (PyArrow >= 3.0 - preferred)
|
|
70
|
+
if hasattr(parquet_file, "iter_batches"):
|
|
71
|
+
logger.info(
|
|
72
|
+
"Reading large parquet file in batches to avoid memory issues"
|
|
73
|
+
)
|
|
74
|
+
for batch in parquet_file.iter_batches(batch_size=batch_size):
|
|
75
|
+
df_batch = batch.to_pandas()
|
|
76
|
+
if not df_batch.empty:
|
|
77
|
+
chunks.extend(dataframe_to_chunks(df_batch))
|
|
78
|
+
batch_count += 1
|
|
79
|
+
|
|
80
|
+
logger.info(
|
|
81
|
+
f"Successfully processed {batch_count} batches from large parquet file"
|
|
82
|
+
)
|
|
83
|
+
return chunks
|
|
84
|
+
|
|
85
|
+
# Method 2: Row group reading (PyArrow >= 0.15.0)
|
|
86
|
+
elif hasattr(parquet_file, "num_row_groups") and hasattr(
|
|
87
|
+
parquet_file, "read_row_group"
|
|
88
|
+
):
|
|
89
|
+
logger.warning(
|
|
90
|
+
"iter_batches not available, using row group reading as fallback"
|
|
91
|
+
)
|
|
92
|
+
|
|
93
|
+
for i in range(parquet_file.num_row_groups):
|
|
94
|
+
try:
|
|
95
|
+
row_group_table = parquet_file.read_row_group(i)
|
|
96
|
+
df_chunk = row_group_table.to_pandas()
|
|
97
|
+
if not df_chunk.empty:
|
|
98
|
+
# Further chunk if row group is still too large
|
|
99
|
+
if len(df_chunk) > batch_size:
|
|
100
|
+
chunks.extend(dataframe_to_chunks(df_chunk))
|
|
101
|
+
else:
|
|
102
|
+
chunks.append(df_chunk)
|
|
103
|
+
batch_count += 1
|
|
104
|
+
except Exception as row_exc:
|
|
105
|
+
logger.warning(f"Failed to read row group {i}: {row_exc}")
|
|
106
|
+
continue
|
|
107
|
+
|
|
108
|
+
if chunks:
|
|
109
|
+
logger.info(
|
|
110
|
+
f"Successfully processed {batch_count} row groups from large parquet file"
|
|
111
|
+
)
|
|
112
|
+
return chunks
|
|
113
|
+
|
|
114
|
+
# Method 3: Regular reading (final fallback)
|
|
115
|
+
logger.warning(
|
|
116
|
+
"No chunking methods available, falling back to regular reading"
|
|
117
|
+
)
|
|
118
|
+
df = parquet_file.read().to_pandas()
|
|
119
|
+
chunks.extend(dataframe_to_chunks(df))
|
|
120
|
+
|
|
121
|
+
except Exception as exc:
|
|
122
|
+
# If all chunking fails, try regular reading as final fallback
|
|
123
|
+
logger.warning(
|
|
124
|
+
f"Batched reading failed: {exc}. Falling back to regular reading - this may cause memory issues for large files"
|
|
125
|
+
)
|
|
126
|
+
try:
|
|
127
|
+
df = parquet_file.read().to_pandas()
|
|
128
|
+
chunks.extend(dataframe_to_chunks(df))
|
|
129
|
+
except Exception as fallback_exc:
|
|
130
|
+
logger.error(f"Failed to read parquet file: {fallback_exc}")
|
|
131
|
+
raise fallback_exc
|
|
132
|
+
|
|
133
|
+
return chunks
|
|
134
|
+
|
|
42
135
|
@singledispatchmethod
|
|
43
136
|
def _read_parquet_dispatch(
|
|
44
137
|
self, config_source: ConfigSource, key: str, bucket_name: str
|
|
@@ -48,24 +141,46 @@ class ParquetDataFrameReader(DataFrameReader):
|
|
|
48
141
|
@_read_parquet_dispatch.register
|
|
49
142
|
def _(self, _: GCSConfig, key: str, bucket_name: str) -> DatalakeColumnWrapper:
|
|
50
143
|
"""
|
|
51
|
-
Read the
|
|
144
|
+
Read the Parquet file from the gcs bucket and return a dataframe
|
|
52
145
|
"""
|
|
53
146
|
# pylint: disable=import-outside-toplevel
|
|
54
147
|
from gcsfs import GCSFileSystem
|
|
55
|
-
from pyarrow.parquet import ParquetFile
|
|
56
148
|
|
|
57
149
|
gcs = GCSFileSystem()
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
150
|
+
file_path = f"gs://{bucket_name}/{key}"
|
|
151
|
+
|
|
152
|
+
# Check file size to determine reading strategy
|
|
153
|
+
try:
|
|
154
|
+
file_info = gcs.info(file_path)
|
|
155
|
+
file_size = file_info.get("size", 0)
|
|
156
|
+
|
|
157
|
+
file = gcs.open(file_path)
|
|
158
|
+
parquet_file = ParquetFile(file)
|
|
159
|
+
|
|
160
|
+
if self._should_use_chunking(file_size):
|
|
161
|
+
# Use batched reading for large files
|
|
162
|
+
return self._read_parquet_in_batches(parquet_file)
|
|
163
|
+
else:
|
|
164
|
+
# Use regular reading for smaller files
|
|
165
|
+
dataframe_response = parquet_file.read().to_pandas(
|
|
166
|
+
split_blocks=True, self_destruct=True
|
|
167
|
+
)
|
|
168
|
+
return dataframe_to_chunks(dataframe_response)
|
|
169
|
+
|
|
170
|
+
except Exception:
|
|
171
|
+
# Fallback to regular reading if size check fails
|
|
172
|
+
file = gcs.open(file_path)
|
|
173
|
+
parquet_file = ParquetFile(file)
|
|
174
|
+
dataframe_response = parquet_file.read().to_pandas(
|
|
175
|
+
split_blocks=True, self_destruct=True
|
|
176
|
+
)
|
|
177
|
+
return dataframe_to_chunks(dataframe_response)
|
|
63
178
|
|
|
64
179
|
@_read_parquet_dispatch.register
|
|
65
180
|
def _(self, _: S3Config, key: str, bucket_name: str) -> DatalakeColumnWrapper:
|
|
66
181
|
# pylint: disable=import-outside-toplevel
|
|
67
182
|
from pyarrow.fs import S3FileSystem
|
|
68
|
-
from pyarrow.parquet import ParquetDataset
|
|
183
|
+
from pyarrow.parquet import ParquetDataset, ParquetFile
|
|
69
184
|
|
|
70
185
|
client_kwargs = {
|
|
71
186
|
"endpoint_override": (
|
|
@@ -90,13 +205,40 @@ class ParquetDataFrameReader(DataFrameReader):
|
|
|
90
205
|
s3_fs = S3FileSystem(**client_kwargs)
|
|
91
206
|
|
|
92
207
|
bucket_uri = f"{bucket_name}/{key}"
|
|
93
|
-
dataset = ParquetDataset(bucket_uri, filesystem=s3_fs)
|
|
94
208
|
|
|
95
|
-
|
|
209
|
+
# Check file size to determine reading strategy
|
|
210
|
+
try:
|
|
211
|
+
file_info = s3_fs.get_file_info(bucket_uri)
|
|
212
|
+
file_size = file_info.size if hasattr(file_info, "size") else 0
|
|
213
|
+
|
|
214
|
+
if self._should_use_chunking(file_size):
|
|
215
|
+
# Use ParquetFile for batched reading of large files
|
|
216
|
+
logger.info(
|
|
217
|
+
f"Large parquet file detected ({file_size} bytes > {MAX_FILE_SIZE_FOR_PREVIEW} bytes). "
|
|
218
|
+
f"Using batched reading for file: {bucket_uri}"
|
|
219
|
+
)
|
|
220
|
+
parquet_file = ParquetFile(bucket_uri, filesystem=s3_fs)
|
|
221
|
+
return self._read_parquet_in_batches(parquet_file)
|
|
222
|
+
else:
|
|
223
|
+
# Use ParquetDataset for regular reading of smaller files
|
|
224
|
+
logger.debug(
|
|
225
|
+
f"Reading small parquet file ({file_size} bytes): {bucket_uri}"
|
|
226
|
+
)
|
|
227
|
+
dataset = ParquetDataset(bucket_uri, filesystem=s3_fs)
|
|
228
|
+
return dataframe_to_chunks(dataset.read_pandas().to_pandas())
|
|
229
|
+
|
|
230
|
+
except Exception as exc:
|
|
231
|
+
# Fallback to regular reading if size check fails
|
|
232
|
+
logger.warning(
|
|
233
|
+
f"Could not determine file size for {bucket_uri}: {exc}. Using regular reading"
|
|
234
|
+
)
|
|
235
|
+
dataset = ParquetDataset(bucket_uri, filesystem=s3_fs)
|
|
236
|
+
return dataframe_to_chunks(dataset.read_pandas().to_pandas())
|
|
96
237
|
|
|
97
238
|
@_read_parquet_dispatch.register
|
|
98
239
|
def _(self, _: AzureConfig, key: str, bucket_name: str) -> DatalakeColumnWrapper:
|
|
99
240
|
import pandas as pd # pylint: disable=import-outside-toplevel
|
|
241
|
+
import pyarrow.fs as fs
|
|
100
242
|
|
|
101
243
|
storage_options = return_azure_storage_options(self.config_source)
|
|
102
244
|
account_url = AZURE_PATH.format(
|
|
@@ -104,8 +246,33 @@ class ParquetDataFrameReader(DataFrameReader):
|
|
|
104
246
|
account_name=self.config_source.securityConfig.accountName,
|
|
105
247
|
key=key,
|
|
106
248
|
)
|
|
107
|
-
|
|
108
|
-
|
|
249
|
+
|
|
250
|
+
# Check file size to determine reading strategy
|
|
251
|
+
try:
|
|
252
|
+
# Try to get file size from Azure
|
|
253
|
+
azure_fs = fs.SubTreeFileSystem(
|
|
254
|
+
account_url, fs.AzureFileSystem(**storage_options)
|
|
255
|
+
)
|
|
256
|
+
file_info = azure_fs.get_file_info("/")
|
|
257
|
+
file_size = file_info.size if hasattr(file_info, "size") else 0
|
|
258
|
+
|
|
259
|
+
if self._should_use_chunking(file_size):
|
|
260
|
+
# Use PyArrow ParquetFile for batched reading of large files
|
|
261
|
+
parquet_file = ParquetFile(
|
|
262
|
+
account_url, filesystem=fs.AzureFileSystem(**storage_options)
|
|
263
|
+
)
|
|
264
|
+
return self._read_parquet_in_batches(parquet_file)
|
|
265
|
+
else:
|
|
266
|
+
# Use pandas for regular reading of smaller files
|
|
267
|
+
dataframe = pd.read_parquet(
|
|
268
|
+
account_url, storage_options=storage_options
|
|
269
|
+
)
|
|
270
|
+
return dataframe_to_chunks(dataframe)
|
|
271
|
+
|
|
272
|
+
except Exception:
|
|
273
|
+
# Fallback to regular pandas reading if size check or batching fails
|
|
274
|
+
dataframe = pd.read_parquet(account_url, storage_options=storage_options)
|
|
275
|
+
return dataframe_to_chunks(dataframe)
|
|
109
276
|
|
|
110
277
|
@_read_parquet_dispatch.register
|
|
111
278
|
def _(
|
|
@@ -114,10 +281,27 @@ class ParquetDataFrameReader(DataFrameReader):
|
|
|
114
281
|
key: str,
|
|
115
282
|
bucket_name: str, # pylint: disable=unused-argument
|
|
116
283
|
) -> DatalakeColumnWrapper:
|
|
284
|
+
import os
|
|
285
|
+
|
|
117
286
|
import pandas as pd # pylint: disable=import-outside-toplevel
|
|
118
287
|
|
|
119
|
-
|
|
120
|
-
|
|
288
|
+
# Check file size to determine reading strategy
|
|
289
|
+
try:
|
|
290
|
+
file_size = os.path.getsize(key)
|
|
291
|
+
|
|
292
|
+
if self._should_use_chunking(file_size):
|
|
293
|
+
# Use PyArrow ParquetFile for batched reading of large files
|
|
294
|
+
parquet_file = ParquetFile(key)
|
|
295
|
+
return self._read_parquet_in_batches(parquet_file)
|
|
296
|
+
else:
|
|
297
|
+
# Use pandas for regular reading of smaller files
|
|
298
|
+
dataframe = pd.read_parquet(key)
|
|
299
|
+
return dataframe_to_chunks(dataframe)
|
|
300
|
+
|
|
301
|
+
except Exception:
|
|
302
|
+
# Fallback to regular pandas reading if size check fails
|
|
303
|
+
dataframe = pd.read_parquet(key)
|
|
304
|
+
return dataframe_to_chunks(dataframe)
|
|
121
305
|
|
|
122
306
|
def _read(self, *, key: str, bucket_name: str, **__) -> DatalakeColumnWrapper:
|
|
123
307
|
return DatalakeColumnWrapper(
|
|
@@ -125,3 +309,6 @@ class ParquetDataFrameReader(DataFrameReader):
|
|
|
125
309
|
self.config_source, key=key, bucket_name=bucket_name
|
|
126
310
|
)
|
|
127
311
|
)
|
|
312
|
+
|
|
313
|
+
def _should_use_chunking(self, file_size: int) -> bool:
|
|
314
|
+
return file_size > MAX_FILE_SIZE_FOR_PREVIEW or file_size == 0
|