castor-extractor 0.24.38__tar.gz → 0.24.42__tar.gz
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 castor-extractor might be problematic. Click here for more details.
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/CHANGELOG.md +18 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/PKG-INFO +19 -1
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/client.py +2 -1
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/client/sources_transformer.py +17 -3
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/strategy/extract.py +1 -1
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/client.py +4 -5
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/client_test.py +2 -1
- castor_extractor-0.24.42/castor_extractor/warehouse/databricks/queries/column_lineage.sql +25 -0
- castor_extractor-0.24.42/castor_extractor/warehouse/databricks/queries/table_lineage.sql +23 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/sql_client.py +14 -11
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/extract.py +3 -1
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/queries/column.sql +3 -3
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/queries/schema.sql +7 -2
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/queries/table.sql +1 -1
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/pyproject.toml +1 -1
- castor_extractor-0.24.38/castor_extractor/warehouse/databricks/lineage.py +0 -69
- castor_extractor-0.24.38/castor_extractor/warehouse/databricks/lineage_test.py +0 -89
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/Dockerfile +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/DockerfileUsage.md +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/LICENCE +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/README.md +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_bigquery.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_confluence.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_databricks.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_domo.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_looker.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_looker_studio.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_metabase_api.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_metabase_db.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_mode.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_mysql.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_notion.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_postgres.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_powerbi.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_qlik.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_redshift.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_salesforce.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_salesforce_reporting.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_sigma.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_snowflake.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_sqlserver.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_strategy.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_tableau.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_thoughtspot.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/file_check.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/upload.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/column.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/column_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/enums.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/file.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/file_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/file_test_users.csv +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/file_test_users_valid.csv +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/templates/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/templates/generic_warehouse.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/client/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/client/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/utils.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/utils_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/client/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/client/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/client/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/logger.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/quality/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/quality/soda/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/quality/soda/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/quality/soda/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/quality/soda/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/quality/soda/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/quality/soda/client/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/quality/soda/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/coalesce/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/coalesce/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/coalesce/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/coalesce/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/coalesce/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/coalesce/client/endpoint.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/coalesce/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/dbt/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/dbt/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/dbt/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/dbt/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/transformation/dbt/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/types.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/constant.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/enums.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/env.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/env_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/settings.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/upload.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/upload_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/uploader/utils.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/argument_parser.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/argument_parser_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/batch.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/batch_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/abstract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/auth.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/auth_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/pagination_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/safe_request.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/safe_request_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/utils.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/api/utils_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/postgres.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/query.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/uri.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/client/uri_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/collection.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/collection_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/deprecate.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/env.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/files.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/files_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/formatter.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/formatter_test.csv +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/formatter_test.json +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/formatter_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/json_stream_write.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/load.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/object.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/object_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/pager/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/pager/pager.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/pager/pager_on_id.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/pager/pager_on_id_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/pager/pager_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/retry.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/retry_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/safe.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/safe_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/salesforce/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/salesforce/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/salesforce/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/salesforce/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/salesforce/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/salesforce/credentials_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/salesforce/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/store.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/string.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/string_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/time.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/time_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/type.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/url.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/url_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/validation.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/validation_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/utils/write.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/client/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/client/pagination_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/domo/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/extraction_parameters.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/sdk.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/sdk_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/api/utils.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/constant.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/fields.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/fields_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker/multithreading.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/admin_sdk_client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/enums.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/looker_studio_api_client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/client/queries/query.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/looker_studio/extract_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/api/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/api/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/api/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/api/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/base_url.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/card.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/collection.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/dashboard.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/dashboard_cards.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/database.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/table.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/db/queries/user.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/decryption.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/decryption_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/client/shared.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/errors.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/metabase/types.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/client/client_test.json +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/client/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/client/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/errors.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/mode/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/authentication.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/credentials_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/powerbi/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/error.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/error_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/json_rpc.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/json_rpc_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/engine/websocket.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/master.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/rest.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/client/rest_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/qlik/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/salesforce_reporting/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/salesforce_reporting/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/salesforce_reporting/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/salesforce_reporting/client/rest.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/salesforce_reporting/client/soql.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/salesforce_reporting/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/client/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/client/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/client/sources_transformer_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/sigma/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/strategy/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/strategy/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/strategy/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/strategy/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/strategy/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/strategy/client/properties.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/client_metadata_api.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/client_metadata_api_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/client_rest_api.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/client_tsc.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/errors.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/gql_queries.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/client/rest_fields.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/tableau/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/thoughtspot/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/thoughtspot/assets.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/thoughtspot/client/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/thoughtspot/client/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/thoughtspot/client/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/thoughtspot/client/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/thoughtspot/client/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/visualization/thoughtspot/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/abstract/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/abstract/asset.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/abstract/asset_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/abstract/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/abstract/query.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/abstract/time_filter.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/abstract/time_filter_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/column.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/cte/sharded.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/database.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/query.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/schema.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/table.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/table_with_tags.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/user.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/queries/view_ddl.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/query.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/bigquery/types.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/api_client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/api_client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/endpoints.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/enums.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/format.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/format_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/types.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/utils.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/databricks/utils_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/queries/column.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/queries/database.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/queries/query.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/queries/schema.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/queries/table.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/queries/user.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/queries/view_ddl.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/mysql/query.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/queries/column.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/queries/database.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/queries/group.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/queries/schema.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/queries/table.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/queries/user.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/postgres/query.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/extract_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/column.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/database.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/group.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/query.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/query_serverless.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/schema.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/table.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/table_freshness.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/user.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/queries/view_ddl.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/redshift/query.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/salesforce/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/salesforce/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/salesforce/constants.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/salesforce/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/salesforce/format.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/salesforce/format_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/salesforce/pagination.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/salesforce/soql.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/client_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/credentials.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/credentials_test.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/extract.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/column.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/column_lineage.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/database.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/function.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/grant_to_role.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/grant_to_user.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/query.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/role.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/schema.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/table.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/user.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/queries/view_ddl.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/snowflake/query.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/__init__.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/client.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/queries/database.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/queries/user.sql +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/sqlserver/query.py +0 -0
- {castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/warehouse/synapse/queries/column.sql +0 -0
|
@@ -1,5 +1,23 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## 0.24.42 - 2025-08-19
|
|
4
|
+
|
|
5
|
+
* Strategy: exclude COLUMNS from extraction
|
|
6
|
+
|
|
7
|
+
## 0.24.41 - 2025-08-19
|
|
8
|
+
|
|
9
|
+
* Sigma: retry on 429 errors when fetching connection paths
|
|
10
|
+
|
|
11
|
+
## 0.24.40 - 2025-08-18
|
|
12
|
+
|
|
13
|
+
* SQLServer: fix database allowlist/blocklist filtering
|
|
14
|
+
|
|
15
|
+
## 0.24.39 - 2025-08-18
|
|
16
|
+
|
|
17
|
+
* Databricks:
|
|
18
|
+
* Fix vanishing owner ID column for tables
|
|
19
|
+
* Deduplicate lineage with SQL to reduce memory use
|
|
20
|
+
|
|
3
21
|
## 0.24.38 - 2025-08-07
|
|
4
22
|
|
|
5
23
|
* Uploader: Support US and EU zones
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: castor-extractor
|
|
3
|
-
Version: 0.24.
|
|
3
|
+
Version: 0.24.42
|
|
4
4
|
Summary: Extract your metadata assets.
|
|
5
5
|
Home-page: https://www.castordoc.com/
|
|
6
6
|
License: EULA
|
|
@@ -215,6 +215,24 @@ For any questions or bug report, contact us at [support@coalesce.io](mailto:supp
|
|
|
215
215
|
|
|
216
216
|
# Changelog
|
|
217
217
|
|
|
218
|
+
## 0.24.42 - 2025-08-19
|
|
219
|
+
|
|
220
|
+
* Strategy: exclude COLUMNS from extraction
|
|
221
|
+
|
|
222
|
+
## 0.24.41 - 2025-08-19
|
|
223
|
+
|
|
224
|
+
* Sigma: retry on 429 errors when fetching connection paths
|
|
225
|
+
|
|
226
|
+
## 0.24.40 - 2025-08-18
|
|
227
|
+
|
|
228
|
+
* SQLServer: fix database allowlist/blocklist filtering
|
|
229
|
+
|
|
230
|
+
## 0.24.39 - 2025-08-18
|
|
231
|
+
|
|
232
|
+
* Databricks:
|
|
233
|
+
* Fix vanishing owner ID column for tables
|
|
234
|
+
* Deduplicate lineage with SQL to reduce memory use
|
|
235
|
+
|
|
218
236
|
## 0.24.38 - 2025-08-07
|
|
219
237
|
|
|
220
238
|
* Uploader: Support US and EU zones
|
|
@@ -28,6 +28,7 @@ POWERBI_DEFAULT_TIMEOUT_S = 30
|
|
|
28
28
|
METADATA_BATCH_SIZE = 100
|
|
29
29
|
POWERBI_SCAN_STATUS_DONE = "Succeeded"
|
|
30
30
|
POWERBI_SCAN_SLEEP_S = 1
|
|
31
|
+
POWERBI_SCAN_TIMEOUT_S = 60
|
|
31
32
|
|
|
32
33
|
MAX_RETRY_PAGES = 1
|
|
33
34
|
RETRY_PAGES_TIMEOUT_MS = 35 * 1000 # 35 seconds
|
|
@@ -142,7 +143,7 @@ class PowerbiClient(APIClient):
|
|
|
142
143
|
endpoint = self.endpoint_factory.metadata_scan_status(scan_id)
|
|
143
144
|
total_waiting_time_s = 0
|
|
144
145
|
|
|
145
|
-
while total_waiting_time_s <
|
|
146
|
+
while total_waiting_time_s < POWERBI_SCAN_TIMEOUT_S:
|
|
146
147
|
try:
|
|
147
148
|
result = self._get(endpoint)
|
|
148
149
|
except HTTPError as e:
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import logging
|
|
2
|
+
from http import HTTPStatus
|
|
2
3
|
from typing import TYPE_CHECKING, Callable, Iterator
|
|
3
4
|
|
|
5
|
+
from ....utils import retry_request
|
|
4
6
|
from .endpoints import SigmaEndpointFactory
|
|
5
7
|
|
|
6
8
|
if TYPE_CHECKING:
|
|
@@ -8,6 +10,9 @@ if TYPE_CHECKING:
|
|
|
8
10
|
|
|
9
11
|
logger = logging.getLogger(__name__)
|
|
10
12
|
|
|
13
|
+
SIGMA_CONNECTION_PATH_MAX_RETRY = 1
|
|
14
|
+
SIGMA_CONNECTION_PATH_SLEEP_MS = 30_000 # 30 seconds
|
|
15
|
+
|
|
11
16
|
|
|
12
17
|
class SigmaSourcesTransformer:
|
|
13
18
|
"""Retrieves asset sources and enhances them with additional information."""
|
|
@@ -15,6 +20,17 @@ class SigmaSourcesTransformer:
|
|
|
15
20
|
def __init__(self, api_client: "SigmaClient"):
|
|
16
21
|
self.api_client = api_client
|
|
17
22
|
|
|
23
|
+
@retry_request(
|
|
24
|
+
status_codes=(HTTPStatus.TOO_MANY_REQUESTS,),
|
|
25
|
+
max_retries=SIGMA_CONNECTION_PATH_MAX_RETRY,
|
|
26
|
+
base_ms=SIGMA_CONNECTION_PATH_SLEEP_MS,
|
|
27
|
+
)
|
|
28
|
+
def _get_connection_path(self, table_id: str) -> dict:
|
|
29
|
+
"""Retrieves the connection path for a given table id"""
|
|
30
|
+
return self.api_client._get(
|
|
31
|
+
endpoint=SigmaEndpointFactory.connection_path(table_id)
|
|
32
|
+
)
|
|
33
|
+
|
|
18
34
|
def _map_table_id_to_connection_path(
|
|
19
35
|
self, all_sources: list
|
|
20
36
|
) -> dict[str, dict]:
|
|
@@ -29,9 +45,7 @@ class SigmaSourcesTransformer:
|
|
|
29
45
|
}
|
|
30
46
|
|
|
31
47
|
return {
|
|
32
|
-
table_id: self.
|
|
33
|
-
endpoint=SigmaEndpointFactory.connection_path(table_id)
|
|
34
|
-
)
|
|
48
|
+
table_id: self._get_connection_path(table_id)
|
|
35
49
|
for table_id in unique_table_ids
|
|
36
50
|
}
|
|
37
51
|
|
|
@@ -22,7 +22,7 @@ def iterate_all_data(
|
|
|
22
22
|
) -> Iterable[tuple[str, Union[list, dict]]]:
|
|
23
23
|
"""Iterate over the extracted data from Strategy"""
|
|
24
24
|
|
|
25
|
-
for asset in StrategyAsset:
|
|
25
|
+
for asset in StrategyAsset.mandatory:
|
|
26
26
|
logger.info(f"Extracting {asset.value.upper()} from REST API")
|
|
27
27
|
data = client.fetch(asset)
|
|
28
28
|
yield asset.name.lower(), list(deep_serialize(data))
|
|
@@ -46,12 +46,11 @@ class DatabricksClient:
|
|
|
46
46
|
|
|
47
47
|
@staticmethod
|
|
48
48
|
def _match_table_with_user(table: dict, user_mapping: dict) -> dict:
|
|
49
|
+
"""Matches the table's owner email to an ID, or None if not found."""
|
|
49
50
|
table_owner_email = table.get("owner_email")
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
if not owner_external_id:
|
|
54
|
-
return table
|
|
51
|
+
owner_external_id = (
|
|
52
|
+
user_mapping.get(table_owner_email) if table_owner_email else None
|
|
53
|
+
)
|
|
55
54
|
return {**table, "owner_external_id": owner_external_id}
|
|
56
55
|
|
|
57
56
|
@staticmethod
|
|
@@ -36,5 +36,6 @@ def test_DatabricksClient__match_table_with_user():
|
|
|
36
36
|
assert table_with_owner == {**table, "owner_external_id": 3}
|
|
37
37
|
|
|
38
38
|
table_without_owner = {"id": 1, "owner_email": None}
|
|
39
|
+
expected = {"id": 1, "owner_email": None, "owner_external_id": None}
|
|
39
40
|
actual = client._match_table_with_user(table_without_owner, user_mapping)
|
|
40
|
-
assert actual ==
|
|
41
|
+
assert actual == expected
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Selects all column lineage events for the given day.
|
|
3
|
+
This excludes self-lineage and deduplicates (parent, child) pairs to keep only the most recent lineage event.
|
|
4
|
+
|
|
5
|
+
Passing parameters is not always supported, so the query must be Python-formatted to set the date.
|
|
6
|
+
*/
|
|
7
|
+
WITH deduplicated_lineage AS (
|
|
8
|
+
SELECT *,
|
|
9
|
+
ROW_NUMBER() OVER (
|
|
10
|
+
PARTITION BY source_table_full_name, source_column_name, target_table_full_name, target_column_name
|
|
11
|
+
ORDER BY event_time DESC
|
|
12
|
+
) AS rank
|
|
13
|
+
FROM system.access.column_lineage
|
|
14
|
+
WHERE
|
|
15
|
+
TRUE
|
|
16
|
+
AND event_date = DATE('{day}')
|
|
17
|
+
AND source_table_full_name IS NOT NULL
|
|
18
|
+
AND source_column_name IS NOT NULL
|
|
19
|
+
AND target_table_full_name IS NOT NULL
|
|
20
|
+
AND target_column_name IS NOT NULL
|
|
21
|
+
AND CONCAT(source_table_full_name, '.', source_column_name) != CONCAT(target_table_full_name, '.', target_column_name)
|
|
22
|
+
)
|
|
23
|
+
SELECT *
|
|
24
|
+
FROM deduplicated_lineage
|
|
25
|
+
WHERE rank = 1
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Selects all table lineage events for the given day.
|
|
3
|
+
This excludes self-lineage and deduplicates (parent, child) pairs to keep only the most recent lineage event.
|
|
4
|
+
|
|
5
|
+
Passing parameters is not always supported, so the query must be Python-formatted to set the date.
|
|
6
|
+
*/
|
|
7
|
+
WITH deduplicated_lineage AS (
|
|
8
|
+
SELECT *,
|
|
9
|
+
ROW_NUMBER() OVER (
|
|
10
|
+
PARTITION BY source_table_full_name, target_table_full_name
|
|
11
|
+
ORDER BY event_time DESC
|
|
12
|
+
) AS rank
|
|
13
|
+
FROM system.access.table_lineage
|
|
14
|
+
WHERE
|
|
15
|
+
TRUE
|
|
16
|
+
AND event_date = DATE('{day}')
|
|
17
|
+
AND source_table_full_name IS NOT NULL
|
|
18
|
+
AND target_table_full_name IS NOT NULL
|
|
19
|
+
AND source_table_full_name != target_table_full_name
|
|
20
|
+
)
|
|
21
|
+
SELECT *
|
|
22
|
+
FROM deduplicated_lineage
|
|
23
|
+
WHERE rank = 1
|
|
@@ -4,20 +4,25 @@ from datetime import date
|
|
|
4
4
|
|
|
5
5
|
from databricks import sql # type: ignore
|
|
6
6
|
|
|
7
|
+
from ...utils import load_file
|
|
7
8
|
from .credentials import DatabricksCredentials
|
|
8
9
|
from .enums import LineageEntity, TagEntity
|
|
9
10
|
from .format import TagMapping
|
|
10
|
-
from .lineage import valid_lineage
|
|
11
11
|
from .utils import build_path, tag_label
|
|
12
12
|
|
|
13
13
|
logger = logging.getLogger(__name__)
|
|
14
14
|
|
|
15
15
|
_INFORMATION_SCHEMA_SQL = "SELECT * FROM system.information_schema"
|
|
16
16
|
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
17
|
+
_LINEAGE_SQL_PATHS = {
|
|
18
|
+
LineageEntity.COLUMN: "queries/column_lineage.sql",
|
|
19
|
+
LineageEntity.TABLE: "queries/table_lineage.sql",
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
def _load_lineage_query(lineage_entity: LineageEntity) -> str:
|
|
24
|
+
filename = _LINEAGE_SQL_PATHS[lineage_entity]
|
|
25
|
+
return load_file(filename, __file__)
|
|
21
26
|
|
|
22
27
|
|
|
23
28
|
class DatabricksSQLClient:
|
|
@@ -95,13 +100,11 @@ class DatabricksSQLClient:
|
|
|
95
100
|
Unfortunately, passing parameters is not always supported. We have to
|
|
96
101
|
format the query beforehand and pass it as plain text for execution.
|
|
97
102
|
"""
|
|
98
|
-
|
|
99
|
-
query =
|
|
100
|
-
|
|
101
|
-
day=day,
|
|
102
|
-
)
|
|
103
|
+
query_template = _load_lineage_query(lineage_entity)
|
|
104
|
+
query = query_template.format(day=day)
|
|
105
|
+
|
|
103
106
|
result = self.execute_sql(query)
|
|
104
107
|
data = []
|
|
105
108
|
for row in result:
|
|
106
109
|
data.append(row.asDict())
|
|
107
|
-
return
|
|
110
|
+
return data
|
|
@@ -52,7 +52,9 @@ def extract_all(**kwargs) -> None:
|
|
|
52
52
|
client = MSSQLClient(credentials=_credentials(kwargs))
|
|
53
53
|
|
|
54
54
|
databases = filter_items(
|
|
55
|
-
client.get_databases(),
|
|
55
|
+
items=client.get_databases(),
|
|
56
|
+
allowed=kwargs.get("db_allowed"),
|
|
57
|
+
blocked=kwargs.get("db_blocked"),
|
|
56
58
|
)
|
|
57
59
|
|
|
58
60
|
query_builder = MSSQLQueryBuilder(
|
|
@@ -91,9 +91,9 @@ columns AS (
|
|
|
91
91
|
LEFT JOIN column_ids AS i
|
|
92
92
|
ON
|
|
93
93
|
(
|
|
94
|
-
c.table_name = i.table_name
|
|
95
|
-
AND c.table_schema = i.schema_name
|
|
96
|
-
AND c.column_name = i.column_name
|
|
94
|
+
c.table_name COLLATE DATABASE_DEFAULT = i.table_name COLLATE DATABASE_DEFAULT
|
|
95
|
+
AND c.table_schema COLLATE DATABASE_DEFAULT = i.schema_name COLLATE DATABASE_DEFAULT
|
|
96
|
+
AND c.column_name COLLATE DATABASE_DEFAULT = i.column_name COLLATE DATABASE_DEFAULT
|
|
97
97
|
)
|
|
98
98
|
)
|
|
99
99
|
|
|
@@ -1,4 +1,9 @@
|
|
|
1
|
-
|
|
1
|
+
/*
|
|
2
|
+
Fetch database information
|
|
3
|
+
|
|
4
|
+
Collation is a set of rules that defines how text data is stored and compared, and it can differ between databases.
|
|
5
|
+
The "COLLATE DATABASE_DEFAULT" is to ensure that text is compared with the same collation.
|
|
6
|
+
*/
|
|
2
7
|
WITH ids AS (
|
|
3
8
|
SELECT DISTINCT
|
|
4
9
|
table_catalog,
|
|
@@ -19,4 +24,4 @@ INNER JOIN ids AS i
|
|
|
19
24
|
LEFT JOIN {database}.sys.sysusers AS u
|
|
20
25
|
ON s.principal_id = u.uid
|
|
21
26
|
LEFT JOIN {database}.sys.databases AS d
|
|
22
|
-
ON i.table_catalog = d.name
|
|
27
|
+
ON i.table_catalog COLLATE DATABASE_DEFAULT = d.name COLLATE DATABASE_DEFAULT
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
from typing import Iterable, Optional
|
|
2
|
-
|
|
3
|
-
from .enums import LineageEntity
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
class LineageProcessor:
|
|
7
|
-
"""
|
|
8
|
-
helper class that handles lineage deduplication and filtering
|
|
9
|
-
"""
|
|
10
|
-
|
|
11
|
-
def __init__(self, lineage_entity: LineageEntity):
|
|
12
|
-
self.lineage_entity = lineage_entity
|
|
13
|
-
|
|
14
|
-
self.lineage: dict[tuple[str, str], dict] = dict()
|
|
15
|
-
|
|
16
|
-
def _parent_path(self, link) -> Optional[str]:
|
|
17
|
-
if self.lineage_entity == LineageEntity.TABLE:
|
|
18
|
-
return link["source_table_full_name"]
|
|
19
|
-
|
|
20
|
-
source_table = link["source_table_full_name"]
|
|
21
|
-
source_column = link["source_column_name"]
|
|
22
|
-
if not (source_table and source_column):
|
|
23
|
-
return None
|
|
24
|
-
|
|
25
|
-
return f"{source_table}.{source_column}"
|
|
26
|
-
|
|
27
|
-
def _child_path(self, link) -> Optional[str]:
|
|
28
|
-
if self.lineage_entity == LineageEntity.TABLE:
|
|
29
|
-
return link["target_table_full_name"]
|
|
30
|
-
|
|
31
|
-
target_table = link["target_table_full_name"]
|
|
32
|
-
target_column = link["target_column_name"]
|
|
33
|
-
if not (target_table and target_column):
|
|
34
|
-
return None
|
|
35
|
-
|
|
36
|
-
return f"{target_table}.{target_column}"
|
|
37
|
-
|
|
38
|
-
def add(self, link: dict) -> None:
|
|
39
|
-
"""
|
|
40
|
-
If the parent and child paths are valid, keeps the most recent lineage
|
|
41
|
-
link in the `self.lineage` map.
|
|
42
|
-
"""
|
|
43
|
-
parent = self._parent_path(link)
|
|
44
|
-
child = self._child_path(link)
|
|
45
|
-
timestamp = link["event_time"]
|
|
46
|
-
|
|
47
|
-
if not (parent and child and parent != child):
|
|
48
|
-
return
|
|
49
|
-
|
|
50
|
-
key = (parent, child)
|
|
51
|
-
if key in self.lineage and self.lineage[key]["event_time"] > timestamp:
|
|
52
|
-
return
|
|
53
|
-
|
|
54
|
-
self.lineage[key] = link
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
def valid_lineage(
|
|
58
|
-
lineage: Iterable[dict], lineage_entity: LineageEntity
|
|
59
|
-
) -> list[dict]:
|
|
60
|
-
"""
|
|
61
|
-
Filters out self-lineage or lineage with a missing source or target path,
|
|
62
|
-
then deduplicates by picking the link with the most recent event timestmap.
|
|
63
|
-
"""
|
|
64
|
-
deduplicated_lineage = LineageProcessor(lineage_entity)
|
|
65
|
-
|
|
66
|
-
for link in lineage:
|
|
67
|
-
deduplicated_lineage.add(link)
|
|
68
|
-
|
|
69
|
-
return list(deduplicated_lineage.lineage.values())
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
from .enums import LineageEntity
|
|
2
|
-
from .lineage import LineageProcessor, valid_lineage
|
|
3
|
-
|
|
4
|
-
_OLDER_DATE = "2025-01-01 00:00:01.0"
|
|
5
|
-
_CLOSER_DATE = "2025-01-01 02:02:02.0"
|
|
6
|
-
|
|
7
|
-
_TABLE_LINEAGES = [
|
|
8
|
-
{
|
|
9
|
-
"source_table_full_name": "a.b.source",
|
|
10
|
-
"target_table_full_name": "a.b.target",
|
|
11
|
-
"event_time": _CLOSER_DATE,
|
|
12
|
-
"other": "more recent stuff",
|
|
13
|
-
},
|
|
14
|
-
{
|
|
15
|
-
"source_table_full_name": "a.b.source",
|
|
16
|
-
"target_table_full_name": "a.b.target",
|
|
17
|
-
"event_time": _OLDER_DATE,
|
|
18
|
-
"other": "stuff that's too old",
|
|
19
|
-
},
|
|
20
|
-
{
|
|
21
|
-
"source_table_full_name": "no target",
|
|
22
|
-
"target_table_full_name": None,
|
|
23
|
-
"event_time": _CLOSER_DATE,
|
|
24
|
-
},
|
|
25
|
-
{
|
|
26
|
-
"source_table_full_name": None,
|
|
27
|
-
"target_table_full_name": "no source",
|
|
28
|
-
"event_time": _CLOSER_DATE,
|
|
29
|
-
},
|
|
30
|
-
]
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
_COLUMN_LINEAGES = [
|
|
34
|
-
{
|
|
35
|
-
"source_table_full_name": "a.b.source",
|
|
36
|
-
"source_column_name": "src_col",
|
|
37
|
-
"target_table_full_name": "a.b.target",
|
|
38
|
-
"target_column_name": "trgt_col",
|
|
39
|
-
"event_time": _OLDER_DATE,
|
|
40
|
-
"other": "old stuff",
|
|
41
|
-
},
|
|
42
|
-
{
|
|
43
|
-
"source_table_full_name": "a.b.source",
|
|
44
|
-
"source_column_name": "src_col",
|
|
45
|
-
"target_table_full_name": "a.b.target",
|
|
46
|
-
"target_column_name": "trgt_col",
|
|
47
|
-
"event_time": _CLOSER_DATE,
|
|
48
|
-
"other": "newer stuff",
|
|
49
|
-
},
|
|
50
|
-
{
|
|
51
|
-
"source_table_full_name": "a.b.toto",
|
|
52
|
-
"source_column_name": "toto_col",
|
|
53
|
-
"target_table_full_name": "a.b.tata",
|
|
54
|
-
"target_column_name": "tata_col",
|
|
55
|
-
"event_time": _OLDER_DATE,
|
|
56
|
-
},
|
|
57
|
-
{
|
|
58
|
-
"source_table_full_name": "a.b.source",
|
|
59
|
-
"source_column_name": "a.b.source",
|
|
60
|
-
"target_table_full_name": None,
|
|
61
|
-
"target_column_name": None,
|
|
62
|
-
"event_time": _CLOSER_DATE,
|
|
63
|
-
},
|
|
64
|
-
]
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
def test_valid_lineage():
|
|
68
|
-
table_links = valid_lineage(_TABLE_LINEAGES, LineageEntity.TABLE)
|
|
69
|
-
|
|
70
|
-
assert len(table_links) == 1
|
|
71
|
-
assert table_links[0]["source_table_full_name"] == "a.b.source"
|
|
72
|
-
assert table_links[0]["target_table_full_name"] == "a.b.target"
|
|
73
|
-
assert table_links[0]["event_time"] == _CLOSER_DATE
|
|
74
|
-
assert table_links[0]["other"] == "more recent stuff"
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
def test_LineageLinks_add():
|
|
78
|
-
deduplicated_lineage = LineageProcessor(LineageEntity.COLUMN)
|
|
79
|
-
for link in _COLUMN_LINEAGES:
|
|
80
|
-
deduplicated_lineage.add(link)
|
|
81
|
-
|
|
82
|
-
lineage = deduplicated_lineage.lineage
|
|
83
|
-
assert len(lineage) == 2
|
|
84
|
-
assert ("a.b.source.src_col", "a.b.target.trgt_col") in lineage
|
|
85
|
-
assert ("a.b.toto.toto_col", "a.b.tata.tata_col") in lineage
|
|
86
|
-
assert (
|
|
87
|
-
lineage[("a.b.source.src_col", "a.b.target.trgt_col")]["other"]
|
|
88
|
-
== "newer stuff"
|
|
89
|
-
)
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_bigquery.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_domo.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_looker.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_mode.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_mysql.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_notion.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_postgres.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_powerbi.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_qlik.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_redshift.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_sigma.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_snowflake.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_sqlserver.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_strategy.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/extract_tableau.py
RENAMED
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/commands/file_check.py
RENAMED
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/__init__.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/column.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/column_test.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/constants.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/enums.py
RENAMED
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/file_checker/file_test.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/confluence/utils.py
RENAMED
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/__init__.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.38 → castor_extractor-0.24.42}/castor_extractor/knowledge/notion/assets.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|