castor-extractor 0.24.43__tar.gz → 0.24.48__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.43 → castor_extractor-0.24.48}/CHANGELOG.md +20 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/PKG-INFO +21 -1
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_sqlserver.py +8 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/coalesce/client/client.py +1 -9
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/client/client.py +1 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/client/pagination.py +1 -1
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/abstract/asset.py +5 -0
- castor_extractor-0.24.48/castor_extractor/warehouse/sqlserver/client.py +159 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/extract.py +8 -1
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/queries/column.sql +8 -8
- castor_extractor-0.24.48/castor_extractor/warehouse/sqlserver/queries/query.sql +25 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/queries/schema.sql +4 -4
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/queries/table.sql +9 -9
- castor_extractor-0.24.48/castor_extractor/warehouse/sqlserver/queries/view_ddl.sql +13 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/pyproject.toml +1 -1
- castor_extractor-0.24.43/castor_extractor/warehouse/sqlserver/client.py +0 -68
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/Dockerfile +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/DockerfileUsage.md +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/LICENCE +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/README.md +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_bigquery.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_confluence.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_databricks.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_domo.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_looker.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_looker_studio.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_metabase_api.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_metabase_db.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_mode.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_mysql.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_notion.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_postgres.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_powerbi.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_qlik.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_redshift.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_salesforce.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_salesforce_reporting.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_sigma.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_snowflake.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_strategy.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_tableau.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_thoughtspot.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/file_check.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/upload.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/column.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/column_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/enums.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/file.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/file_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/file_test_users.csv +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/file_test_users_valid.csv +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/templates/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/templates/generic_warehouse.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/client/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/client/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/client/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/utils.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/confluence/utils_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/client/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/client/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/client/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/client/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/knowledge/notion/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/logger.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/quality/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/quality/soda/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/quality/soda/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/quality/soda/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/quality/soda/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/quality/soda/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/quality/soda/client/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/quality/soda/client/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/coalesce/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/coalesce/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/coalesce/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/coalesce/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/coalesce/client/endpoint.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/coalesce/client/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/dbt/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/dbt/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/dbt/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/dbt/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/transformation/dbt/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/types.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/constant.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/enums.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/env.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/env_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/settings.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/upload.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/upload_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/uploader/utils.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/argument_parser.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/argument_parser_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/batch.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/batch_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/abstract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/auth.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/auth_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/pagination_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/safe_request.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/safe_request_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/utils.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/api/utils_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/postgres.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/query.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/uri.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/client/uri_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/collection.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/collection_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/deprecate.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/env.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/files.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/files_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/formatter.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/formatter_test.csv +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/formatter_test.json +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/formatter_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/json_stream_write.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/load.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/object.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/object_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/pager/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/pager/pager.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/pager/pager_on_id.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/pager/pager_on_id_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/pager/pager_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/retry.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/retry_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/safe.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/safe_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/salesforce/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/salesforce/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/salesforce/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/salesforce/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/salesforce/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/salesforce/credentials_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/salesforce/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/store.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/string.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/string_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/time.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/time_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/type.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/url.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/url_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/validation.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/validation_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/utils/write.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/client/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/client/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/client/pagination_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/domo/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/extraction_parameters.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/sdk.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/sdk_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/api/utils.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/constant.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/fields.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/fields_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker/multithreading.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/admin_sdk_client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/enums.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/looker_studio_api_client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/client/queries/query.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/looker_studio/extract_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/api/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/api/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/api/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/api/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/base_url.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/card.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/collection.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/dashboard.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/dashboard_cards.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/database.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/table.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/db/queries/user.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/decryption.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/decryption_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/client/shared.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/errors.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/metabase/types.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/client/client_test.json +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/client/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/client/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/errors.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/mode/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/authentication.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/credentials_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/client/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/powerbi/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/error.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/error_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/json_rpc.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/json_rpc_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/engine/websocket.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/master.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/rest.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/client/rest_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/qlik/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/salesforce_reporting/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/salesforce_reporting/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/salesforce_reporting/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/salesforce_reporting/client/rest.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/salesforce_reporting/client/soql.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/salesforce_reporting/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/client/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/client/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/client/sources_transformer.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/client/sources_transformer_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/sigma/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/strategy/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/strategy/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/strategy/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/strategy/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/strategy/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/strategy/client/properties.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/strategy/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/client_metadata_api.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/client_metadata_api_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/client_rest_api.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/client_tsc.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/errors.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/gql_queries.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/client/rest_fields.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/tableau/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/thoughtspot/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/thoughtspot/assets.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/thoughtspot/client/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/thoughtspot/client/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/thoughtspot/client/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/thoughtspot/client/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/thoughtspot/client/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/visualization/thoughtspot/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/abstract/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/abstract/asset_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/abstract/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/abstract/query.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/abstract/time_filter.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/abstract/time_filter_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/column.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/cte/sharded.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/database.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/query.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/schema.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/table.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/table_with_tags.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/user.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/queries/view_ddl.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/query.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/bigquery/types.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/api_client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/api_client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/endpoints.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/enums.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/format.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/format_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/queries/column_lineage.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/queries/table_lineage.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/sql_client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/types.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/utils.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/databricks/utils_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/queries/column.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/queries/database.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/queries/query.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/queries/schema.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/queries/table.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/queries/user.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/queries/view_ddl.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/mysql/query.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/queries/column.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/queries/database.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/queries/group.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/queries/schema.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/queries/table.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/queries/user.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/postgres/query.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/extract_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/column.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/database.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/group.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/query.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/query_serverless.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/schema.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/table.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/table_freshness.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/user.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/queries/view_ddl.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/redshift/query.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/salesforce/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/salesforce/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/salesforce/constants.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/salesforce/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/salesforce/format.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/salesforce/format_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/salesforce/pagination.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/salesforce/soql.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/client.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/client_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/credentials.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/credentials_test.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/extract.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/column.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/column_lineage.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/database.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/function.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/grant_to_role.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/grant_to_user.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/query.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/role.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/schema.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/table.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/user.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/queries/view_ddl.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/snowflake/query.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/__init__.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/queries/.sqlfluff +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/queries/database.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/queries/user.sql +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/sqlserver/query.py +0 -0
- {castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/synapse/queries/column.sql +0 -0
|
@@ -1,5 +1,25 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## 0.24.48 - 2025-09-09
|
|
4
|
+
|
|
5
|
+
* SqlServer: handle hyphens in database name
|
|
6
|
+
|
|
7
|
+
## 0.24.47 - 2025-09-08
|
|
8
|
+
|
|
9
|
+
* SqlServer: extract SQL queries and lineage
|
|
10
|
+
|
|
11
|
+
## 0.24.46 - 2025-09-03
|
|
12
|
+
|
|
13
|
+
* Sigma: Added `HTTPStatus.FORBIDDEN` to the list of ignored errors
|
|
14
|
+
|
|
15
|
+
## 0.24.45 - 2025-08-27
|
|
16
|
+
|
|
17
|
+
* Sigma: Increasing pagination limit for Sigma extraction
|
|
18
|
+
|
|
19
|
+
## 0.24.44 - 2025-08-22
|
|
20
|
+
|
|
21
|
+
* Coalesce: do not skip nodes raising a 500 Server Error
|
|
22
|
+
|
|
3
23
|
## 0.24.43 - 2025-08-20
|
|
4
24
|
|
|
5
25
|
* SQLServer:
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: castor-extractor
|
|
3
|
-
Version: 0.24.
|
|
3
|
+
Version: 0.24.48
|
|
4
4
|
Summary: Extract your metadata assets.
|
|
5
5
|
Home-page: https://www.castordoc.com/
|
|
6
6
|
License: EULA
|
|
@@ -215,6 +215,26 @@ For any questions or bug report, contact us at [support@coalesce.io](mailto:supp
|
|
|
215
215
|
|
|
216
216
|
# Changelog
|
|
217
217
|
|
|
218
|
+
## 0.24.48 - 2025-09-09
|
|
219
|
+
|
|
220
|
+
* SqlServer: handle hyphens in database name
|
|
221
|
+
|
|
222
|
+
## 0.24.47 - 2025-09-08
|
|
223
|
+
|
|
224
|
+
* SqlServer: extract SQL queries and lineage
|
|
225
|
+
|
|
226
|
+
## 0.24.46 - 2025-09-03
|
|
227
|
+
|
|
228
|
+
* Sigma: Added `HTTPStatus.FORBIDDEN` to the list of ignored errors
|
|
229
|
+
|
|
230
|
+
## 0.24.45 - 2025-08-27
|
|
231
|
+
|
|
232
|
+
* Sigma: Increasing pagination limit for Sigma extraction
|
|
233
|
+
|
|
234
|
+
## 0.24.44 - 2025-08-22
|
|
235
|
+
|
|
236
|
+
* Coalesce: do not skip nodes raising a 500 Server Error
|
|
237
|
+
|
|
218
238
|
## 0.24.43 - 2025-08-20
|
|
219
239
|
|
|
220
240
|
* SQLServer:
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_sqlserver.py
RENAMED
|
@@ -15,6 +15,14 @@ def main():
|
|
|
15
15
|
parser.add_argument("-u", "--user", help="MSSQL User")
|
|
16
16
|
parser.add_argument("-p", "--password", help="MSSQL Password")
|
|
17
17
|
|
|
18
|
+
parser.add_argument(
|
|
19
|
+
"-s",
|
|
20
|
+
"--skip-queries",
|
|
21
|
+
dest="skip_queries",
|
|
22
|
+
action="store_true",
|
|
23
|
+
help="Skip the extraction of SQL queries",
|
|
24
|
+
)
|
|
25
|
+
|
|
18
26
|
parser.add_argument("-o", "--output", help="Directory to write to")
|
|
19
27
|
|
|
20
28
|
parser.add_argument(
|
|
@@ -3,8 +3,6 @@ from functools import partial
|
|
|
3
3
|
from http import HTTPStatus
|
|
4
4
|
from typing import Callable, Optional
|
|
5
5
|
|
|
6
|
-
from pydantic import ValidationError
|
|
7
|
-
|
|
8
6
|
from ....utils import (
|
|
9
7
|
APIClient,
|
|
10
8
|
BearerAuth,
|
|
@@ -123,13 +121,7 @@ class CoalesceClient(APIClient):
|
|
|
123
121
|
for index, env in enumerate(environments):
|
|
124
122
|
env_id = env["id"]
|
|
125
123
|
logger.info(f"Fetching nodes for env #{env_id} - {index}/{total}")
|
|
126
|
-
|
|
127
|
-
nodes.extend(self._fetch_env_nodes(env_id))
|
|
128
|
-
except ValidationError as e:
|
|
129
|
-
# 500 Server Error: Internal Server Error on Coalesce API
|
|
130
|
-
logger.warning(
|
|
131
|
-
f"Skipping nodes for {env_id} due to the following Error: {e}"
|
|
132
|
-
)
|
|
124
|
+
nodes.extend(self._fetch_env_nodes(env_id))
|
|
133
125
|
logger.info(f"{len(nodes)} nodes extracted so far")
|
|
134
126
|
return nodes
|
|
135
127
|
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/warehouse/abstract/asset.py
RENAMED
|
@@ -64,6 +64,11 @@ FUNCTIONS_ASSETS = (WarehouseAsset.FUNCTION,)
|
|
|
64
64
|
QUERIES_ASSETS = (WarehouseAsset.QUERY,)
|
|
65
65
|
VIEWS_ASSETS = (WarehouseAsset.VIEW_DDL,)
|
|
66
66
|
|
|
67
|
+
QUERIES_ASSET_GROUPS = (
|
|
68
|
+
WarehouseAssetGroup.QUERY,
|
|
69
|
+
WarehouseAssetGroup.VIEW_DDL,
|
|
70
|
+
)
|
|
71
|
+
|
|
67
72
|
EXTERNAL_LINEAGE_ASSETS = (
|
|
68
73
|
WarehouseAsset.EXTERNAL_COLUMN_LINEAGE,
|
|
69
74
|
WarehouseAsset.EXTERNAL_TABLE_LINEAGE,
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import logging
|
|
2
|
+
from collections.abc import Iterator
|
|
3
|
+
|
|
4
|
+
from sqlalchemy import text
|
|
5
|
+
|
|
6
|
+
from ...utils import ExtractionQuery, SqlalchemyClient, uri_encode
|
|
7
|
+
|
|
8
|
+
logger = logging.getLogger(__name__)
|
|
9
|
+
|
|
10
|
+
SERVER_URI = "{user}:{password}@{host}:{port}/{database}"
|
|
11
|
+
MSSQL_URI = f"mssql+pymssql://{SERVER_URI}"
|
|
12
|
+
DEFAULT_PORT = 1433
|
|
13
|
+
|
|
14
|
+
_KEYS = ("user", "password", "host", "port", "database")
|
|
15
|
+
|
|
16
|
+
_SYSTEM_DATABASES = ("master", "model", "msdb", "tempdb", "DBAdmin")
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
def _check_key(credentials: dict) -> None:
|
|
20
|
+
for key in _KEYS:
|
|
21
|
+
if key not in credentials:
|
|
22
|
+
raise KeyError(f"Missing {key} in credentials")
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
class MSSQLClient(SqlalchemyClient):
|
|
26
|
+
"""Microsoft Server SQL client"""
|
|
27
|
+
|
|
28
|
+
@staticmethod
|
|
29
|
+
def name() -> str:
|
|
30
|
+
return "MSSQL"
|
|
31
|
+
|
|
32
|
+
def _engine_options(self, credentials: dict) -> dict:
|
|
33
|
+
return {}
|
|
34
|
+
|
|
35
|
+
def _build_uri(self, credentials: dict) -> str:
|
|
36
|
+
_check_key(credentials)
|
|
37
|
+
uri = MSSQL_URI.format(
|
|
38
|
+
user=credentials["user"],
|
|
39
|
+
password=uri_encode(credentials["password"]),
|
|
40
|
+
host=credentials["host"],
|
|
41
|
+
port=credentials.get("port") or DEFAULT_PORT,
|
|
42
|
+
database=credentials["database"],
|
|
43
|
+
)
|
|
44
|
+
return uri
|
|
45
|
+
|
|
46
|
+
def execute(self, query: ExtractionQuery) -> Iterator[dict]:
|
|
47
|
+
"""
|
|
48
|
+
Re-implements the SQLAlchemyClient execute function to ensure we consume
|
|
49
|
+
the cursor before calling connection.close() as it wipes out the data
|
|
50
|
+
otherwise
|
|
51
|
+
"""
|
|
52
|
+
connection = self.connect()
|
|
53
|
+
try:
|
|
54
|
+
proxy = connection.execute(text(query.statement), query.params)
|
|
55
|
+
results = list(self._process_result(proxy))
|
|
56
|
+
yield from results
|
|
57
|
+
finally:
|
|
58
|
+
self.close()
|
|
59
|
+
|
|
60
|
+
def get_databases(self) -> list[str]:
|
|
61
|
+
result = self.execute(
|
|
62
|
+
ExtractionQuery("SELECT name FROM sys.databases", {})
|
|
63
|
+
)
|
|
64
|
+
return [
|
|
65
|
+
row["name"]
|
|
66
|
+
for row in result
|
|
67
|
+
if row["name"] not in _SYSTEM_DATABASES
|
|
68
|
+
]
|
|
69
|
+
|
|
70
|
+
def _current_database(self) -> str:
|
|
71
|
+
result = self.execute(
|
|
72
|
+
ExtractionQuery("SELECT DB_NAME() AS database_name", {})
|
|
73
|
+
)
|
|
74
|
+
return next(result)["database_name"]
|
|
75
|
+
|
|
76
|
+
def _has_access(self, name: str, object_type: str, permission: str) -> bool:
|
|
77
|
+
query_text = f"""
|
|
78
|
+
SELECT
|
|
79
|
+
HAS_PERMS_BY_NAME('{name}', '{object_type}', '{permission}')
|
|
80
|
+
AS has_permission
|
|
81
|
+
"""
|
|
82
|
+
query = ExtractionQuery(query_text, dict())
|
|
83
|
+
result = next(self.execute(query))
|
|
84
|
+
return result["has_permission"] == 1
|
|
85
|
+
|
|
86
|
+
def _has_table_read_access(self, table_name: str) -> bool:
|
|
87
|
+
"""
|
|
88
|
+
Check whether we have READ access to the given table
|
|
89
|
+
"""
|
|
90
|
+
return self._has_access(
|
|
91
|
+
name=table_name,
|
|
92
|
+
object_type="OBJECT",
|
|
93
|
+
permission="SELECT",
|
|
94
|
+
)
|
|
95
|
+
|
|
96
|
+
def _has_view_database_state(self) -> bool:
|
|
97
|
+
"""
|
|
98
|
+
Check whether we have VIEW DATABASE STATE permissions, which
|
|
99
|
+
is necessary to fetch data from the Query Store
|
|
100
|
+
"""
|
|
101
|
+
return self._has_access(
|
|
102
|
+
name=self._current_database(),
|
|
103
|
+
object_type="DATABASE",
|
|
104
|
+
permission="VIEW DATABASE STATE",
|
|
105
|
+
)
|
|
106
|
+
|
|
107
|
+
def _has_query_store(self) -> bool:
|
|
108
|
+
"""
|
|
109
|
+
Checks whether the Query Store is activated on this instance.
|
|
110
|
+
This is required to extract the SQL queries history.
|
|
111
|
+
https://learn.microsoft.com/en-us/sql/relational-databases/performance/monitoring-performance-by-using-the-query-store?view=sql-server-ver17"""
|
|
112
|
+
sql = """
|
|
113
|
+
SELECT
|
|
114
|
+
desired_state
|
|
115
|
+
FROM
|
|
116
|
+
sys.database_query_store_options
|
|
117
|
+
"""
|
|
118
|
+
query = ExtractionQuery(sql, {})
|
|
119
|
+
# 2 = READ_WRITE, which means the Query Store is activated
|
|
120
|
+
return next(self.execute(query))["desired_state"] == 2
|
|
121
|
+
|
|
122
|
+
def has_queries_permissions(self) -> bool:
|
|
123
|
+
"""
|
|
124
|
+
Verify that we habe the required permissions to extract
|
|
125
|
+
query history and view object definitions (DDL).
|
|
126
|
+
|
|
127
|
+
This check ensures:
|
|
128
|
+
- Query Store is enabled on the database.
|
|
129
|
+
- We have the VIEW DATABASE STATE permissions
|
|
130
|
+
- We have read access to the relevant system tables.
|
|
131
|
+
"""
|
|
132
|
+
|
|
133
|
+
tables = (
|
|
134
|
+
# SQL queries
|
|
135
|
+
"sys.query_store_plan",
|
|
136
|
+
"sys.query_store_query",
|
|
137
|
+
"sys.query_store_query_text",
|
|
138
|
+
"sys.query_store_runtime_stats",
|
|
139
|
+
# views DDL
|
|
140
|
+
"sys.schemas",
|
|
141
|
+
"sys.sql_modules",
|
|
142
|
+
"sys.views",
|
|
143
|
+
)
|
|
144
|
+
|
|
145
|
+
has_permissions = True
|
|
146
|
+
for table in tables:
|
|
147
|
+
if not self._has_table_read_access(table):
|
|
148
|
+
logger.info(f"Missing READ permissions for table {table}")
|
|
149
|
+
has_permissions = False
|
|
150
|
+
|
|
151
|
+
if not self._has_view_database_state():
|
|
152
|
+
logger.info("Missing permissions: VIEW DATABASE STATE")
|
|
153
|
+
has_permissions = False
|
|
154
|
+
|
|
155
|
+
if not self._has_query_store():
|
|
156
|
+
logger.info("Missing permissions: Query Store is not activated")
|
|
157
|
+
has_permissions = False
|
|
158
|
+
|
|
159
|
+
return has_permissions
|
|
@@ -4,6 +4,8 @@ from ...utils import LocalStorage, filter_items, from_env, write_summary
|
|
|
4
4
|
from ..abstract import (
|
|
5
5
|
CATALOG_ASSETS,
|
|
6
6
|
EXTERNAL_LINEAGE_ASSETS,
|
|
7
|
+
QUERIES_ASSETS,
|
|
8
|
+
VIEWS_ASSETS,
|
|
7
9
|
SQLExtractionProcessor,
|
|
8
10
|
SupportedAssets,
|
|
9
11
|
WarehouseAsset,
|
|
@@ -19,8 +21,10 @@ logger = logging.getLogger(__name__)
|
|
|
19
21
|
|
|
20
22
|
MSSQL_ASSETS: SupportedAssets = {
|
|
21
23
|
WarehouseAssetGroup.CATALOG: CATALOG_ASSETS,
|
|
22
|
-
WarehouseAssetGroup.ROLE: (WarehouseAsset.USER,),
|
|
23
24
|
WarehouseAssetGroup.EXTERNAL_LINEAGE: EXTERNAL_LINEAGE_ASSETS,
|
|
25
|
+
WarehouseAssetGroup.QUERY: QUERIES_ASSETS,
|
|
26
|
+
WarehouseAssetGroup.ROLE: (WarehouseAsset.USER,),
|
|
27
|
+
WarehouseAssetGroup.VIEW_DDL: VIEWS_ASSETS,
|
|
24
28
|
}
|
|
25
29
|
|
|
26
30
|
|
|
@@ -71,7 +75,10 @@ def extract_all(**kwargs) -> None:
|
|
|
71
75
|
storage=storage,
|
|
72
76
|
)
|
|
73
77
|
|
|
78
|
+
skip_queries = kwargs.get("skip_queries") or False
|
|
74
79
|
for group in extractable_asset_groups(MSSQL_ASSETS):
|
|
80
|
+
if group == WarehouseAssetGroup.QUERY and skip_queries:
|
|
81
|
+
continue
|
|
75
82
|
for asset in group:
|
|
76
83
|
logger.info(f"Extracting `{asset.value.upper()}` ...")
|
|
77
84
|
location = extractor.extract(asset, skip_existing)
|
|
@@ -11,7 +11,7 @@ WITH extended_tables AS (
|
|
|
11
11
|
table_owner_id = principal_id,
|
|
12
12
|
schema_id
|
|
13
13
|
FROM
|
|
14
|
-
{database}.sys.tables
|
|
14
|
+
[{database}].sys.tables
|
|
15
15
|
|
|
16
16
|
UNION
|
|
17
17
|
|
|
@@ -21,7 +21,7 @@ WITH extended_tables AS (
|
|
|
21
21
|
table_owner_id = principal_id,
|
|
22
22
|
schema_id
|
|
23
23
|
FROM
|
|
24
|
-
{database}.sys.views
|
|
24
|
+
[{database}].sys.views
|
|
25
25
|
|
|
26
26
|
UNION
|
|
27
27
|
|
|
@@ -31,7 +31,7 @@ WITH extended_tables AS (
|
|
|
31
31
|
table_owner_id = principal_id,
|
|
32
32
|
schema_id
|
|
33
33
|
FROM
|
|
34
|
-
{database}.sys.external_tables
|
|
34
|
+
[{database}].sys.external_tables
|
|
35
35
|
),
|
|
36
36
|
/*
|
|
37
37
|
`sys.columns` contains, among others:
|
|
@@ -54,11 +54,11 @@ column_ids AS (
|
|
|
54
54
|
schema_name = ss.name,
|
|
55
55
|
schema_id = ss.schema_id,
|
|
56
56
|
comment = CONVERT(varchar(1024), ep.value)
|
|
57
|
-
FROM {database}.sys.columns AS sc
|
|
57
|
+
FROM [{database}].sys.columns AS sc
|
|
58
58
|
LEFT JOIN extended_tables AS et ON sc.object_id = et.table_id
|
|
59
|
-
LEFT JOIN {database}.sys.schemas AS ss ON et.schema_id = ss.schema_id
|
|
60
|
-
LEFT JOIN {database}.sys.databases AS sd ON sd.name = '{database}'
|
|
61
|
-
LEFT JOIN {database}.sys.extended_properties AS ep
|
|
59
|
+
LEFT JOIN [{database}].sys.schemas AS ss ON et.schema_id = ss.schema_id
|
|
60
|
+
LEFT JOIN [{database}].sys.databases AS sd ON sd.name = '{database}'
|
|
61
|
+
LEFT JOIN [{database}].sys.extended_properties AS ep
|
|
62
62
|
ON
|
|
63
63
|
sc.object_id = ep.major_id
|
|
64
64
|
AND sc.column_id = ep.minor_id
|
|
@@ -87,7 +87,7 @@ columns AS (
|
|
|
87
87
|
i.comment,
|
|
88
88
|
column_id = CONCAT(i.table_id, '.', c.column_name)
|
|
89
89
|
FROM
|
|
90
|
-
{database}.INFORMATION_SCHEMA.COLUMNS AS c
|
|
90
|
+
[{database}].INFORMATION_SCHEMA.COLUMNS AS c
|
|
91
91
|
LEFT JOIN column_ids AS i
|
|
92
92
|
ON
|
|
93
93
|
(
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
SELECT
|
|
2
|
+
q.query_id,
|
|
3
|
+
qt.query_sql_text as query_text,
|
|
4
|
+
rs.count_executions,
|
|
5
|
+
rs.last_duration as duration,
|
|
6
|
+
rs.last_execution_time as start_time,
|
|
7
|
+
'unknown-user' as user_name,
|
|
8
|
+
'unknown-user' as user_id,
|
|
9
|
+
DATEADD(SECOND, last_duration / 1000000,
|
|
10
|
+
DATEADD(MICROSECOND, last_duration % 1000000, rs.last_execution_time)
|
|
11
|
+
) AS end_time
|
|
12
|
+
FROM
|
|
13
|
+
sys.query_store_runtime_stats AS rs
|
|
14
|
+
INNER JOIN
|
|
15
|
+
sys.query_store_plan p
|
|
16
|
+
ON rs.plan_id = p.plan_id
|
|
17
|
+
INNER JOIN
|
|
18
|
+
sys.query_store_query q
|
|
19
|
+
ON p.query_id = q.query_id
|
|
20
|
+
INNER JOIN
|
|
21
|
+
sys.query_store_query_text qt
|
|
22
|
+
ON q.query_text_id = qt.query_text_id
|
|
23
|
+
WHERE
|
|
24
|
+
CAST(rs.last_execution_time AS DATE) = :day
|
|
25
|
+
AND DATEPART(HOUR, rs.last_execution_time) BETWEEN :hour_min AND :hour_max
|
|
@@ -8,7 +8,7 @@ WITH ids AS (
|
|
|
8
8
|
SELECT DISTINCT
|
|
9
9
|
table_catalog,
|
|
10
10
|
table_schema
|
|
11
|
-
FROM {database}.INFORMATION_SCHEMA.TABLES
|
|
11
|
+
FROM [{database}].INFORMATION_SCHEMA.TABLES
|
|
12
12
|
)
|
|
13
13
|
|
|
14
14
|
SELECT
|
|
@@ -18,10 +18,10 @@ SELECT
|
|
|
18
18
|
schema_id = CAST(d.database_id AS VARCHAR(10)) + '_' + CAST(s.schema_id AS VARCHAR(10)),
|
|
19
19
|
schema_owner = u.name,
|
|
20
20
|
schema_owner_id = u.uid
|
|
21
|
-
FROM {database}.sys.schemas AS s
|
|
21
|
+
FROM [{database}].sys.schemas AS s
|
|
22
22
|
INNER JOIN ids AS i
|
|
23
23
|
ON s.name = i.table_schema
|
|
24
|
-
LEFT JOIN {database}.sys.sysusers AS u
|
|
24
|
+
LEFT JOIN [{database}].sys.sysusers AS u
|
|
25
25
|
ON s.principal_id = u.uid
|
|
26
|
-
LEFT JOIN {database}.sys.databases AS d
|
|
26
|
+
LEFT JOIN [{database}].sys.databases AS d
|
|
27
27
|
ON i.table_catalog COLLATE DATABASE_DEFAULT = d.name COLLATE DATABASE_DEFAULT
|
|
@@ -11,7 +11,7 @@ WITH extended_tables AS (
|
|
|
11
11
|
table_owner_id = principal_id,
|
|
12
12
|
schema_id
|
|
13
13
|
FROM
|
|
14
|
-
{database}.sys.tables
|
|
14
|
+
[{database}].sys.tables
|
|
15
15
|
|
|
16
16
|
UNION
|
|
17
17
|
|
|
@@ -21,7 +21,7 @@ WITH extended_tables AS (
|
|
|
21
21
|
table_owner_id = principal_id,
|
|
22
22
|
schema_id
|
|
23
23
|
FROM
|
|
24
|
-
{database}.sys.views
|
|
24
|
+
[{database}].sys.views
|
|
25
25
|
|
|
26
26
|
UNION
|
|
27
27
|
|
|
@@ -31,14 +31,14 @@ WITH extended_tables AS (
|
|
|
31
31
|
table_owner_id = principal_id,
|
|
32
32
|
schema_id
|
|
33
33
|
FROM
|
|
34
|
-
{database}.sys.external_tables
|
|
34
|
+
[{database}].sys.external_tables
|
|
35
35
|
),
|
|
36
36
|
-- Get the row count per table
|
|
37
37
|
partitions AS (
|
|
38
38
|
SELECT
|
|
39
39
|
object_id,
|
|
40
40
|
row_count = SUM(rows)
|
|
41
|
-
FROM {database}.sys.partitions
|
|
41
|
+
FROM [{database}].sys.partitions
|
|
42
42
|
GROUP BY object_id
|
|
43
43
|
),
|
|
44
44
|
-- Append row count to table properties
|
|
@@ -70,11 +70,11 @@ table_ids AS (
|
|
|
70
70
|
row_count,
|
|
71
71
|
comment = CONVERT(varchar(1024), ep.value)
|
|
72
72
|
FROM extended_tables_with_row_count AS et
|
|
73
|
-
LEFT JOIN {database}.sys.schemas AS ss
|
|
73
|
+
LEFT JOIN [{database}].sys.schemas AS ss
|
|
74
74
|
ON et.schema_id = ss.schema_id
|
|
75
|
-
LEFT JOIN {database}.sys.sysusers AS u
|
|
75
|
+
LEFT JOIN [{database}].sys.sysusers AS u
|
|
76
76
|
ON et.table_owner_id = u.uid
|
|
77
|
-
LEFT JOIN {database}.sys.extended_properties AS ep
|
|
77
|
+
LEFT JOIN [{database}].sys.extended_properties AS ep
|
|
78
78
|
ON (
|
|
79
79
|
et.table_id = ep.major_id
|
|
80
80
|
AND ep.minor_id = 0
|
|
@@ -90,8 +90,8 @@ meta AS (
|
|
|
90
90
|
t.table_name,
|
|
91
91
|
t.table_type
|
|
92
92
|
FROM
|
|
93
|
-
{database}.INFORMATION_SCHEMA.TABLES AS t
|
|
94
|
-
LEFT JOIN {database}.sys.databases AS db
|
|
93
|
+
[{database}].INFORMATION_SCHEMA.TABLES AS t
|
|
94
|
+
LEFT JOIN [{database}].sys.databases AS db
|
|
95
95
|
ON t.table_catalog COLLATE DATABASE_DEFAULT = db.name COLLATE DATABASE_DEFAULT
|
|
96
96
|
)
|
|
97
97
|
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
SELECT
|
|
2
|
+
v.name AS view_name,
|
|
3
|
+
m.definition AS view_definition,
|
|
4
|
+
s.name AS schema_name,
|
|
5
|
+
DB_NAME() AS database_name
|
|
6
|
+
FROM
|
|
7
|
+
sys.views v
|
|
8
|
+
INNER JOIN
|
|
9
|
+
sys.schemas s
|
|
10
|
+
ON v.schema_id = s.schema_id
|
|
11
|
+
INNER JOIN
|
|
12
|
+
sys.sql_modules m
|
|
13
|
+
ON v.object_id = m.object_id
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import logging
|
|
2
|
-
from collections.abc import Iterator
|
|
3
|
-
|
|
4
|
-
from sqlalchemy import text
|
|
5
|
-
|
|
6
|
-
from ...utils import ExtractionQuery, SqlalchemyClient, uri_encode
|
|
7
|
-
|
|
8
|
-
logger = logging.getLogger(__name__)
|
|
9
|
-
|
|
10
|
-
SERVER_URI = "{user}:{password}@{host}:{port}/{database}"
|
|
11
|
-
MSSQL_URI = f"mssql+pymssql://{SERVER_URI}"
|
|
12
|
-
DEFAULT_PORT = 1433
|
|
13
|
-
|
|
14
|
-
_KEYS = ("user", "password", "host", "port", "database")
|
|
15
|
-
|
|
16
|
-
_SYSTEM_DATABASES = ("master", "model", "msdb", "tempdb", "DBAdmin")
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
def _check_key(credentials: dict) -> None:
|
|
20
|
-
for key in _KEYS:
|
|
21
|
-
if key not in credentials:
|
|
22
|
-
raise KeyError(f"Missing {key} in credentials")
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
class MSSQLClient(SqlalchemyClient):
|
|
26
|
-
"""Microsoft Server SQL client"""
|
|
27
|
-
|
|
28
|
-
@staticmethod
|
|
29
|
-
def name() -> str:
|
|
30
|
-
return "MSSQL"
|
|
31
|
-
|
|
32
|
-
def _engine_options(self, credentials: dict) -> dict:
|
|
33
|
-
return {}
|
|
34
|
-
|
|
35
|
-
def _build_uri(self, credentials: dict) -> str:
|
|
36
|
-
_check_key(credentials)
|
|
37
|
-
uri = MSSQL_URI.format(
|
|
38
|
-
user=credentials["user"],
|
|
39
|
-
password=uri_encode(credentials["password"]),
|
|
40
|
-
host=credentials["host"],
|
|
41
|
-
port=credentials.get("port") or DEFAULT_PORT,
|
|
42
|
-
database=credentials["database"],
|
|
43
|
-
)
|
|
44
|
-
return uri
|
|
45
|
-
|
|
46
|
-
def execute(self, query: ExtractionQuery) -> Iterator[dict]:
|
|
47
|
-
"""
|
|
48
|
-
Re-implements the SQLAlchemyClient execute function to ensure we consume
|
|
49
|
-
the cursor before calling connection.close() as it wipes out the data
|
|
50
|
-
otherwise
|
|
51
|
-
"""
|
|
52
|
-
connection = self.connect()
|
|
53
|
-
try:
|
|
54
|
-
proxy = connection.execute(text(query.statement), query.params)
|
|
55
|
-
results = list(self._process_result(proxy))
|
|
56
|
-
yield from results
|
|
57
|
-
finally:
|
|
58
|
-
self.close()
|
|
59
|
-
|
|
60
|
-
def get_databases(self) -> list[str]:
|
|
61
|
-
result = self.execute(
|
|
62
|
-
ExtractionQuery("SELECT name FROM sys.databases", {})
|
|
63
|
-
)
|
|
64
|
-
return [
|
|
65
|
-
row["name"]
|
|
66
|
-
for row in result
|
|
67
|
-
if row["name"] not in _SYSTEM_DATABASES
|
|
68
|
-
]
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_bigquery.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_domo.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_looker.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_mode.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_mysql.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_notion.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_postgres.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_powerbi.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_qlik.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_redshift.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_sigma.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_snowflake.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_strategy.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/extract_tableau.py
RENAMED
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/commands/file_check.py
RENAMED
|
File without changes
|
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/__init__.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/column.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/column_test.py
RENAMED
|
File without changes
|
{castor_extractor-0.24.43 → castor_extractor-0.24.48}/castor_extractor/file_checker/constants.py
RENAMED
|
File without changes
|