castor-extractor 0.18.2__tar.gz → 0.18.5__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.18.2 → castor_extractor-0.18.5}/CHANGELOG.md +12 -0
- castor_extractor-0.18.5/DockerfileUsage.md +21 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/PKG-INFO +1 -1
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_domo.py +2 -10
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_looker.py +2 -13
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_metabase_api.py +4 -10
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_metabase_db.py +4 -16
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_mode.py +2 -12
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_powerbi.py +2 -8
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_qlik.py +2 -7
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_salesforce.py +3 -12
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_salesforce_reporting.py +2 -10
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_sigma.py +2 -7
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/__init__.py +1 -0
- castor_extractor-0.18.5/castor_extractor/utils/argument_parser.py +7 -0
- castor_extractor-0.18.5/castor_extractor/utils/argument_parser_test.py +25 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/extract.py +4 -19
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/extract.py +2 -3
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/extract.py +2 -2
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/extract.py +4 -3
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/extract.py +4 -15
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/extract.py +3 -6
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/salesforce_reporting/extract.py +6 -20
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/extract.py +4 -13
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/client.py +3 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/salesforce/format.py +5 -3
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/pyproject.toml +1 -1
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/Dockerfile +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/LICENCE +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/README.md +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_bigquery.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_databricks.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_mysql.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_postgres.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_redshift.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_snowflake.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_sqlserver.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_tableau.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/file_check.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/upload.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/column.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/column_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/enums.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/file.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/file_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/file_test_users.csv +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/file_test_users_valid.csv +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/templates/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/templates/generic_warehouse.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/logger.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/types.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/uploader/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/uploader/constant.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/uploader/env.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/uploader/env_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/uploader/upload.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/uploader/upload_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/uploader/utils.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/client/abstract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/client/api.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/client/api_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/client/postgres.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/client/query.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/client/uri.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/client/uri_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/collection.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/collection_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/dbt/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/dbt/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/dbt/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/dbt/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/dbt/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/deprecate.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/env.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/files.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/files_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/formatter.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/formatter_test.csv +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/formatter_test.json +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/formatter_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/json_stream_write.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/load.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/object.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/object_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/pager/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/pager/pager.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/pager/pager_on_id.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/pager/pager_on_id_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/pager/pager_on_token.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/pager/pager_on_token_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/pager/pager_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/retry.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/retry_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/safe.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/safe_request.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/safe_request_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/safe_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/salesforce/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/salesforce/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/salesforce/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/salesforce/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/salesforce/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/salesforce/credentials_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/store.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/string.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/string_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/time.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/time_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/type.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/validation.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/validation_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/utils/write.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/client/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/client/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/client/endpoints.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/client/pagination.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/client/pagination_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/extraction_parameters.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/sdk.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/sdk_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/api/utils.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/constant.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/fields.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/fields_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/multithreading.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/api/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/api/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/api/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/api/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/.sqlfluff +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/base_url.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/card.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/collection.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/dashboard.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/dashboard_cards.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/database.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/table.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/db/queries/user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/decryption.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/decryption_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/client/shared.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/errors.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/metabase/types.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/client/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/client/client_test.json +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/client/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/client/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/client/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/errors.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/client/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/client/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/client/credentials_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/client/rest.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/client/rest_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/client/utils.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/powerbi/client/utils_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/error.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/error_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/json_rpc.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/json_rpc_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/engine/websocket.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/master.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/rest.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/client/rest_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/salesforce_reporting/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/salesforce_reporting/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/salesforce_reporting/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/salesforce_reporting/client/rest.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/salesforce_reporting/client/soql.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/client/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/client/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/client/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/client/endpoints.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/client/pagination.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/client/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/client/client_utils.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/client/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/client/project.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/client/safe_mode.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/errors.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/gql_fields.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/assets/graphql/metadata/metadata_1_get.json +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/assets/graphql/metadata/metadata_2_get.json +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/auth.xml +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/project_get.xml +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/user_get.xml +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/view_get_usage.xml +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/workbook_get.xml +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/graphql/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/graphql/paginated_object_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/rest_api/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/rest_api/auth_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/rest_api/credentials_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/rest_api/projects_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/rest_api/usages_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/rest_api/users_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/rest_api/workbooks_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/utils/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tests/unit/utils/env_key.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/tsc_fields.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/types.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau/usage.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/assets.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/client/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/client/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/client/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/client/errors.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/client/gql_queries.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/client/tsc_fields.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/tableau_revamp/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/abstract/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/abstract/asset.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/abstract/asset_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/abstract/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/abstract/query.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/abstract/time_filter.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/abstract/time_filter_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/.sqlfluff +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/column.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/cte/sharded.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/database.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/query.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/schema.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/table.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/table_with_tags.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/queries/view_ddl.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/query.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/bigquery/types.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/format.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/format_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/test_constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/types.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/utils.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/utils_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/queries/.sqlfluff +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/queries/column.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/queries/database.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/queries/query.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/queries/schema.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/queries/table.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/queries/user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/queries/view_ddl.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/mysql/query.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/queries/.sqlfluff +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/queries/column.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/queries/database.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/queries/group.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/queries/schema.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/queries/table.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/queries/user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/postgres/query.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/.sqlfluff +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/column.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/database.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/group.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/query.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/schema.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/table.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/table_freshness.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/queries/view_ddl.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/redshift/query.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/salesforce/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/salesforce/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/salesforce/constants.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/salesforce/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/salesforce/format_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/salesforce/soql.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/client_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/credentials.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/credentials_test.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/.sqlfluff +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/column.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/column_lineage.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/database.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/function.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/grant_to_role.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/grant_to_user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/query.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/role.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/schema.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/table.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/queries/view_ddl.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/snowflake/query.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/client.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/queries/.sqlfluff +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/queries/column.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/queries/database.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/queries/schema.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/queries/table.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/queries/user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/sqlserver/query.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/__init__.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/extract.py +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/queries/.sqlfluff +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/queries/column.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/queries/database.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/queries/query.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/queries/schema.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/queries/table.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/queries/user.sql +0 -0
- {castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/synapse/queries/view_ddl.sql +0 -0
|
@@ -1,5 +1,17 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## 0.18.5 - 2024-07-17
|
|
4
|
+
|
|
5
|
+
* Salesforce: extract DeveloperName and tooling url
|
|
6
|
+
|
|
7
|
+
## 0.18.4 - 2024-07-16
|
|
8
|
+
|
|
9
|
+
* Fix environment variables assignments for credentials
|
|
10
|
+
|
|
11
|
+
## 0.18.3 - 2024-07-16
|
|
12
|
+
|
|
13
|
+
* bump dependencies (minor and patches)
|
|
14
|
+
|
|
3
15
|
## 0.18.2 - 2024-07-08
|
|
4
16
|
|
|
5
17
|
* Added StatusCode handling to SafeMode
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
# Dockerfile usage for CastorDoc package
|
|
2
|
+
|
|
3
|
+
## How To
|
|
4
|
+
|
|
5
|
+
- The Dockerfile is present on the pypi package
|
|
6
|
+
- For building it you should use this command `docker build -t castor-extractor-looker --build-arg EXTRA=looker .` with replacing looker one or several of: [bigquery,looker,metabase,powerbi,qlik,redshift,snowflake,tableau]
|
|
7
|
+
- For running it you should do `docker run -v <local-path>:/data --env-file <castor-extract-looker.env> castor-extractor-looker` where `</local-path>` have to be replaced and `<castor-extract-looker.env>` have to be set.
|
|
8
|
+
- Extracted datas would be available on `<local-path>`. The path should exists
|
|
9
|
+
- `<castor-extract-looker.env>` would contain env vars for credentials, url...
|
|
10
|
+
|
|
11
|
+
#### example
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
docker run -v /logs:/data --env-file /config/castor-extract-looker.env castor-extractor-looker
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
## Limitation
|
|
18
|
+
|
|
19
|
+
- This docker image is for a specific techno
|
|
20
|
+
- This docker image is based on python 3.11
|
|
21
|
+
- This docker image use the latest castor-extractor package version
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_domo.py
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.visualization import domo # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -38,13 +39,4 @@ def main():
|
|
|
38
39
|
|
|
39
40
|
parser.add_argument("-o", "--output", help="Directory to write to")
|
|
40
41
|
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
domo.extract_all(
|
|
44
|
-
api_token=args.api_token,
|
|
45
|
-
base_url=args.base_url,
|
|
46
|
-
client_id=args.client_id,
|
|
47
|
-
cloud_id=args.cloud_id,
|
|
48
|
-
developer_token=args.developer_token,
|
|
49
|
-
output_directory=args.output,
|
|
50
|
-
)
|
|
42
|
+
domo.extract_all(**parse_filled_arguments(parser))
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_looker.py
RENAMED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
from argparse import ArgumentParser
|
|
2
2
|
|
|
3
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
3
4
|
from castor_extractor.visualization import looker # type: ignore
|
|
4
5
|
|
|
5
6
|
|
|
@@ -33,16 +34,4 @@ def main():
|
|
|
33
34
|
action="store_true",
|
|
34
35
|
)
|
|
35
36
|
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
looker.extract_all(
|
|
39
|
-
base_url=args.base_url,
|
|
40
|
-
client_id=args.username,
|
|
41
|
-
client_secret=args.password,
|
|
42
|
-
log_to_stdout=args.log_to_stdout,
|
|
43
|
-
output_directory=args.output,
|
|
44
|
-
safe_mode=args.safe_mode,
|
|
45
|
-
search_per_folder=args.search_per_folder,
|
|
46
|
-
thread_pool_size=args.thread_pool_size,
|
|
47
|
-
timeout=args.timeout,
|
|
48
|
-
)
|
|
37
|
+
looker.extract_all(**parse_filled_arguments(parser))
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.visualization import metabase # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -15,16 +16,9 @@ def main():
|
|
|
15
16
|
|
|
16
17
|
parser.add_argument("-o", "--output", help="Directory to write to")
|
|
17
18
|
|
|
18
|
-
args = parser
|
|
19
|
+
args = parse_filled_arguments(parser)
|
|
19
20
|
|
|
20
|
-
credentials = metabase.MetabaseApiCredentials(
|
|
21
|
-
base_url=args.base_url,
|
|
22
|
-
user=args.username,
|
|
23
|
-
password=args.password,
|
|
24
|
-
)
|
|
21
|
+
credentials = metabase.MetabaseApiCredentials(**args)
|
|
25
22
|
client = metabase.ApiClient(credentials)
|
|
26
23
|
|
|
27
|
-
metabase.extract_all(
|
|
28
|
-
client,
|
|
29
|
-
output_directory=args.output,
|
|
30
|
-
)
|
|
24
|
+
metabase.extract_all(client, **args)
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_metabase_db.py
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.visualization import metabase # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -33,22 +34,9 @@ def main():
|
|
|
33
34
|
|
|
34
35
|
parser.add_argument("-o", "--output", help="Directory to write to")
|
|
35
36
|
|
|
36
|
-
args = parser
|
|
37
|
-
|
|
38
|
-
credentials = metabase.MetabaseDbCredentials(
|
|
39
|
-
host=args.host,
|
|
40
|
-
port=args.port,
|
|
41
|
-
database=args.database,
|
|
42
|
-
schema=args.schema,
|
|
43
|
-
user=args.username,
|
|
44
|
-
password=args.password,
|
|
45
|
-
encryption_secret_key=args.encryption_secret_key,
|
|
46
|
-
require_ssl=args.require_ssl,
|
|
47
|
-
)
|
|
37
|
+
args = parse_filled_arguments(parser)
|
|
38
|
+
credentials = metabase.MetabaseDbCredentials(**args)
|
|
48
39
|
|
|
49
40
|
client = metabase.DbClient(credentials)
|
|
50
41
|
|
|
51
|
-
metabase.extract_all(
|
|
52
|
-
client,
|
|
53
|
-
output_directory=args.output,
|
|
54
|
-
)
|
|
42
|
+
metabase.extract_all(client, **args)
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_mode.py
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.visualization import mode # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -24,15 +25,4 @@ def main():
|
|
|
24
25
|
|
|
25
26
|
parser.add_argument("-o", "--output", help="Directory to write to")
|
|
26
27
|
|
|
27
|
-
|
|
28
|
-
credentials = mode.Credentials(
|
|
29
|
-
host=args.host,
|
|
30
|
-
workspace=args.workspace,
|
|
31
|
-
token=args.token,
|
|
32
|
-
secret=args.secret,
|
|
33
|
-
)
|
|
34
|
-
|
|
35
|
-
mode.extract_all(
|
|
36
|
-
credentials,
|
|
37
|
-
output_directory=args.output,
|
|
38
|
-
)
|
|
28
|
+
mode.extract_all(**parse_filled_arguments(parser))
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_powerbi.py
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.visualization import powerbi # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -20,11 +21,4 @@ def main():
|
|
|
20
21
|
)
|
|
21
22
|
parser.add_argument("-o", "--output", help="Directory to write to")
|
|
22
23
|
|
|
23
|
-
|
|
24
|
-
powerbi.extract_all(
|
|
25
|
-
tenant_id=args.tenant_id,
|
|
26
|
-
client_id=args.client_id,
|
|
27
|
-
secret=args.secret,
|
|
28
|
-
scopes=args.scopes,
|
|
29
|
-
output_directory=args.output,
|
|
30
|
-
)
|
|
24
|
+
powerbi.extract_all(**parse_filled_arguments(parser))
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_qlik.py
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.visualization import qlik # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -22,10 +23,4 @@ def main():
|
|
|
22
23
|
"missing rights on some assets.",
|
|
23
24
|
)
|
|
24
25
|
|
|
25
|
-
|
|
26
|
-
qlik.extract_all(
|
|
27
|
-
base_url=args.base_url,
|
|
28
|
-
api_key=args.api_key,
|
|
29
|
-
output_directory=args.output,
|
|
30
|
-
except_http_error_statuses=args.except_http_error_statuses,
|
|
31
|
-
)
|
|
26
|
+
qlik.extract_all(**parse_filled_arguments(parser))
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_salesforce.py
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.warehouse import salesforce # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -29,15 +30,5 @@ def main():
|
|
|
29
30
|
)
|
|
30
31
|
parser.set_defaults(skip_existing=False)
|
|
31
32
|
|
|
32
|
-
args = parser
|
|
33
|
-
|
|
34
|
-
salesforce.extract_all(
|
|
35
|
-
username=args.username,
|
|
36
|
-
password=args.password,
|
|
37
|
-
client_id=args.client_id,
|
|
38
|
-
client_secret=args.client_secret,
|
|
39
|
-
security_token=args.security_token,
|
|
40
|
-
base_url=args.base_url,
|
|
41
|
-
output_directory=args.output,
|
|
42
|
-
skip_existing=args.skip_existing,
|
|
43
|
-
)
|
|
33
|
+
args = parse_filled_arguments(parser)
|
|
34
|
+
salesforce.extract_all(output_directory=args.get("output"), **args)
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.visualization import salesforce_reporting # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -21,13 +22,4 @@ def main():
|
|
|
21
22
|
parser.add_argument("-b", "--base-url", help="Salesforce instance URL")
|
|
22
23
|
parser.add_argument("-o", "--output", help="Directory to write to")
|
|
23
24
|
|
|
24
|
-
|
|
25
|
-
salesforce_reporting.extract_all(
|
|
26
|
-
username=args.username,
|
|
27
|
-
password=args.password,
|
|
28
|
-
client_id=args.client_id,
|
|
29
|
-
client_secret=args.client_secret,
|
|
30
|
-
security_token=args.security_token,
|
|
31
|
-
base_url=args.base_url,
|
|
32
|
-
output_directory=args.output,
|
|
33
|
-
)
|
|
25
|
+
salesforce_reporting.extract_all(**parse_filled_arguments(parser))
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_sigma.py
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import logging
|
|
2
2
|
from argparse import ArgumentParser
|
|
3
3
|
|
|
4
|
+
from castor_extractor.utils import parse_filled_arguments # type: ignore
|
|
4
5
|
from castor_extractor.visualization import sigma # type: ignore
|
|
5
6
|
|
|
6
7
|
logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
|
|
@@ -14,10 +15,4 @@ def main():
|
|
|
14
15
|
parser.add_argument("-a", "--api-token", help="Generated API key")
|
|
15
16
|
parser.add_argument("-o", "--output", help="Directory to write to")
|
|
16
17
|
|
|
17
|
-
|
|
18
|
-
sigma.extract_all(
|
|
19
|
-
host=args.host,
|
|
20
|
-
client_id=args.client_id,
|
|
21
|
-
api_token=args.api_token,
|
|
22
|
-
output_directory=args.output,
|
|
23
|
-
)
|
|
18
|
+
sigma.extract_all(**parse_filled_arguments(parser))
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
from argparse import ArgumentParser
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
def parse_filled_arguments(parser: ArgumentParser) -> dict:
|
|
5
|
+
"""Parse arguments and remove all those with None values"""
|
|
6
|
+
parsed_arguments = vars(parser.parse_args())
|
|
7
|
+
return {k: v for k, v in parsed_arguments.items() if v is not None}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
from argparse import Namespace
|
|
2
|
+
|
|
3
|
+
from .argument_parser import parse_filled_arguments
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class MockArgumentParser:
|
|
7
|
+
|
|
8
|
+
def __init__(self):
|
|
9
|
+
self.attributes = {}
|
|
10
|
+
|
|
11
|
+
def add_argument(self, name, value):
|
|
12
|
+
self.attributes[name] = value
|
|
13
|
+
|
|
14
|
+
def parse_args(self) -> Namespace:
|
|
15
|
+
return Namespace(**self.attributes)
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
def test_parse_filled_arguments():
|
|
19
|
+
parser = MockArgumentParser()
|
|
20
|
+
parser.add_argument("filled", "value")
|
|
21
|
+
parser.add_argument("unfilled", None)
|
|
22
|
+
parser.add_argument("empty_str", "")
|
|
23
|
+
|
|
24
|
+
expected = {"filled": "value", "empty_str": ""}
|
|
25
|
+
assert parse_filled_arguments(parser) == expected
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/domo/extract.py
RENAMED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import logging
|
|
2
|
-
from typing import Iterable, Iterator,
|
|
2
|
+
from typing import Iterable, Iterator, Tuple, Union
|
|
3
3
|
|
|
4
4
|
from ...utils import (
|
|
5
5
|
OUTPUT_DIR,
|
|
@@ -42,28 +42,13 @@ def iterate_all_data(
|
|
|
42
42
|
yield DomoAsset.DATAFLOWS, list(deep_serialize(dataflows))
|
|
43
43
|
|
|
44
44
|
|
|
45
|
-
def extract_all(
|
|
46
|
-
api_token: Optional[str] = None,
|
|
47
|
-
base_url: Optional[str] = None,
|
|
48
|
-
client_id: Optional[str] = None,
|
|
49
|
-
cloud_id: Optional[str] = None,
|
|
50
|
-
developer_token: Optional[str] = None,
|
|
51
|
-
output_directory: Optional[str] = None,
|
|
52
|
-
) -> None:
|
|
45
|
+
def extract_all(**kwargs) -> None:
|
|
53
46
|
"""
|
|
54
47
|
Extract data from Domo API
|
|
55
48
|
Store the output files locally under the given output_directory
|
|
56
49
|
"""
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
credentials = DomoCredentials(
|
|
61
|
-
base_url=base_url,
|
|
62
|
-
client_id=client_id,
|
|
63
|
-
api_token=api_token,
|
|
64
|
-
developer_token=developer_token,
|
|
65
|
-
cloud_id=cloud_id,
|
|
66
|
-
)
|
|
50
|
+
_output_directory = kwargs.get("output") or from_env(OUTPUT_DIR)
|
|
51
|
+
credentials = DomoCredentials(**kwargs)
|
|
67
52
|
client = DomoClient(credentials=credentials)
|
|
68
53
|
|
|
69
54
|
ts = current_timestamp()
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/looker/extract.py
RENAMED
|
@@ -126,11 +126,10 @@ def extract_all(**kwargs) -> None:
|
|
|
126
126
|
Extract Data From looker and store it locally in files under the
|
|
127
127
|
output_directory
|
|
128
128
|
"""
|
|
129
|
-
|
|
130
|
-
extraction_parameters = ExtractionParameters(**args)
|
|
129
|
+
extraction_parameters = ExtractionParameters(**kwargs)
|
|
131
130
|
output_directory = extraction_parameters.output_directory
|
|
132
131
|
|
|
133
|
-
credentials = LookerCredentials(**
|
|
132
|
+
credentials = LookerCredentials(**kwargs)
|
|
134
133
|
|
|
135
134
|
if extraction_parameters.log_to_stdout:
|
|
136
135
|
set_stream_handler_to_stdout()
|
|
@@ -40,12 +40,12 @@ def iterate_all_data(
|
|
|
40
40
|
)
|
|
41
41
|
|
|
42
42
|
|
|
43
|
-
def extract_all(client: ClientMetabase, **kwargs
|
|
43
|
+
def extract_all(client: ClientMetabase, **kwargs) -> None:
|
|
44
44
|
"""
|
|
45
45
|
Extract Data From metabase
|
|
46
46
|
Store the output files locally under the given output_directory
|
|
47
47
|
"""
|
|
48
|
-
output_directory = kwargs.get("
|
|
48
|
+
output_directory = kwargs.get("output") or from_env(OUTPUT_DIR)
|
|
49
49
|
ts = current_timestamp()
|
|
50
50
|
|
|
51
51
|
for key, data in iterate_all_data(client):
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/mode/extract.py
RENAMED
|
@@ -37,11 +37,12 @@ def iterate_all_data(
|
|
|
37
37
|
yield Asset.MEMBER, deep_serialize(members)
|
|
38
38
|
|
|
39
39
|
|
|
40
|
-
def extract_all(
|
|
40
|
+
def extract_all(**kwargs) -> None:
|
|
41
41
|
"""Extract Data From Mode Analytics and store it locally in files under the output_directory"""
|
|
42
|
-
output_directory =
|
|
43
|
-
|
|
42
|
+
output_directory = kwargs.get("output") or from_env(OUTPUT_DIR)
|
|
43
|
+
credentials = ModeCredentials(**kwargs)
|
|
44
44
|
client = Client(credentials)
|
|
45
|
+
|
|
45
46
|
ts = current_timestamp()
|
|
46
47
|
|
|
47
48
|
for key, data in iterate_all_data(client):
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
from typing import Iterable, List,
|
|
1
|
+
from typing import Iterable, List, Tuple, Union
|
|
2
2
|
|
|
3
3
|
from ...utils import (
|
|
4
4
|
OUTPUT_DIR,
|
|
@@ -24,24 +24,13 @@ def iterate_all_data(
|
|
|
24
24
|
yield asset, deep_serialize(data)
|
|
25
25
|
|
|
26
26
|
|
|
27
|
-
def extract_all(
|
|
28
|
-
tenant_id: str,
|
|
29
|
-
client_id: str,
|
|
30
|
-
secret: str,
|
|
31
|
-
scopes: Optional[List[str]] = None,
|
|
32
|
-
output_directory: Optional[str] = None,
|
|
33
|
-
) -> None:
|
|
27
|
+
def extract_all(**kwargs) -> None:
|
|
34
28
|
"""
|
|
35
29
|
Extract data from PowerBI REST API
|
|
36
30
|
Store the output files locally under the given output_directory
|
|
37
31
|
"""
|
|
38
|
-
_output_directory =
|
|
39
|
-
creds = PowerbiCredentials(
|
|
40
|
-
tenant_id=tenant_id,
|
|
41
|
-
client_id=client_id,
|
|
42
|
-
secret=secret,
|
|
43
|
-
scopes=scopes,
|
|
44
|
-
)
|
|
32
|
+
_output_directory = kwargs.get("output") or from_env(OUTPUT_DIR)
|
|
33
|
+
creds = PowerbiCredentials(**kwargs)
|
|
45
34
|
client = Client(creds)
|
|
46
35
|
ts = current_timestamp()
|
|
47
36
|
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/qlik/extract.py
RENAMED
|
@@ -47,18 +47,15 @@ def iterate_all_data(
|
|
|
47
47
|
|
|
48
48
|
|
|
49
49
|
def extract_all(
|
|
50
|
-
|
|
51
|
-
api_key: Optional[str] = None,
|
|
52
|
-
output_directory: Optional[str] = None,
|
|
53
|
-
except_http_error_statuses: Optional[List[int]] = None,
|
|
50
|
+
except_http_error_statuses: Optional[List[int]] = None, **kwargs
|
|
54
51
|
) -> None:
|
|
55
52
|
"""
|
|
56
53
|
Extract data from Qlik REST API
|
|
57
54
|
Store the output files locally under the given output_directory
|
|
58
55
|
"""
|
|
59
56
|
|
|
60
|
-
credentials = QlikCredentials(
|
|
61
|
-
_output_directory =
|
|
57
|
+
credentials = QlikCredentials(**kwargs)
|
|
58
|
+
_output_directory = kwargs.get("output") or from_env(OUTPUT_DIR)
|
|
62
59
|
|
|
63
60
|
client = QlikClient(
|
|
64
61
|
credentials=credentials,
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import logging
|
|
2
|
-
from typing import Iterable,
|
|
2
|
+
from typing import Iterable, Tuple, Union
|
|
3
3
|
|
|
4
4
|
from ...utils import (
|
|
5
5
|
OUTPUT_DIR,
|
|
@@ -28,29 +28,15 @@ def iterate_all_data(
|
|
|
28
28
|
yield asset.name.lower(), deep_serialize(data)
|
|
29
29
|
|
|
30
30
|
|
|
31
|
-
def extract_all(
|
|
32
|
-
username: str,
|
|
33
|
-
password: str,
|
|
34
|
-
client_id: str,
|
|
35
|
-
client_secret: str,
|
|
36
|
-
security_token: str,
|
|
37
|
-
base_url: str,
|
|
38
|
-
output_directory: Optional[str] = None,
|
|
39
|
-
) -> None:
|
|
31
|
+
def extract_all(**kwargs) -> None:
|
|
40
32
|
"""
|
|
41
33
|
Extract data from Salesforce REST API
|
|
42
34
|
Store the output files locally under the given output_directory
|
|
43
35
|
"""
|
|
44
|
-
_output_directory =
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
client_id=client_id,
|
|
49
|
-
client_secret=client_secret,
|
|
50
|
-
security_token=security_token,
|
|
51
|
-
base_url=base_url,
|
|
52
|
-
)
|
|
53
|
-
client = SalesforceReportingClient(credentials=creds)
|
|
36
|
+
_output_directory = kwargs.get("output") or from_env(OUTPUT_DIR)
|
|
37
|
+
credentials = SalesforceCredentials(**kwargs)
|
|
38
|
+
|
|
39
|
+
client = SalesforceReportingClient(credentials=credentials)
|
|
54
40
|
ts = current_timestamp()
|
|
55
41
|
|
|
56
42
|
for key, data in iterate_all_data(client):
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/visualization/sigma/extract.py
RENAMED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import logging
|
|
2
|
-
from typing import Iterable, Iterator,
|
|
2
|
+
from typing import Iterable, Iterator, Tuple, Union
|
|
3
3
|
|
|
4
4
|
from ...utils import (
|
|
5
5
|
OUTPUT_DIR,
|
|
@@ -50,24 +50,15 @@ def iterate_all_data(
|
|
|
50
50
|
yield SigmaAsset.LINEAGES, list(deep_serialize(lineages))
|
|
51
51
|
|
|
52
52
|
|
|
53
|
-
def extract_all(
|
|
54
|
-
host: Optional[str] = None,
|
|
55
|
-
client_id: Optional[str] = None,
|
|
56
|
-
api_token: Optional[str] = None,
|
|
57
|
-
output_directory: Optional[str] = None,
|
|
58
|
-
) -> None:
|
|
53
|
+
def extract_all(**kwargs) -> None:
|
|
59
54
|
"""
|
|
60
55
|
Extract data from Sigma API
|
|
61
56
|
Store the output files locally under the given output_directory
|
|
62
57
|
"""
|
|
63
58
|
|
|
64
|
-
_output_directory =
|
|
59
|
+
_output_directory = kwargs.get("output") or from_env(OUTPUT_DIR)
|
|
65
60
|
|
|
66
|
-
credentials = SigmaCredentials(
|
|
67
|
-
host=host,
|
|
68
|
-
client_id=client_id,
|
|
69
|
-
api_token=api_token,
|
|
70
|
-
)
|
|
61
|
+
credentials = SigmaCredentials(**kwargs)
|
|
71
62
|
client = SigmaClient(credentials=credentials)
|
|
72
63
|
|
|
73
64
|
ts = current_timestamp()
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/databricks/client.py
RENAMED
|
@@ -28,6 +28,7 @@ from .utils import build_path, tag_label
|
|
|
28
28
|
|
|
29
29
|
logger = logging.getLogger(__name__)
|
|
30
30
|
|
|
31
|
+
_DATABRICKS_CLIENT_TIMEOUT = 60
|
|
31
32
|
_MAX_NUMBER_OF_LINEAGE_ERRORS = 1000
|
|
32
33
|
_MAX_THREADS = 10
|
|
33
34
|
_RETRY_ATTEMPTS = 3
|
|
@@ -98,6 +99,8 @@ class DatabricksClient(APIClient):
|
|
|
98
99
|
self._db_blocked = db_blocked
|
|
99
100
|
self._has_table_tags = has_table_tags
|
|
100
101
|
self._has_column_tags = has_column_tags
|
|
102
|
+
|
|
103
|
+
self._timeout = _DATABRICKS_CLIENT_TIMEOUT
|
|
101
104
|
self.formatter = DatabricksFormatter()
|
|
102
105
|
|
|
103
106
|
def execute_sql(
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/warehouse/salesforce/format.py
RENAMED
|
@@ -26,12 +26,14 @@ def _field_description(field: Dict[str, Any]) -> str:
|
|
|
26
26
|
def _to_column_payload(field: dict, position: int, table_name: str) -> dict:
|
|
27
27
|
field_name = field["QualifiedApiName"]
|
|
28
28
|
return {
|
|
29
|
-
"id": f"{table_name}.{field_name}",
|
|
30
|
-
"table_id": table_name,
|
|
31
29
|
"column_name": field_name,
|
|
32
|
-
"description": _field_description(field),
|
|
33
30
|
"data_type": field.get("DataType"),
|
|
31
|
+
"description": _field_description(field),
|
|
32
|
+
"id": f"{table_name}.{field_name}",
|
|
34
33
|
"ordinal_position": position,
|
|
34
|
+
"salesforce_developer_name": field.get("DeveloperName"),
|
|
35
|
+
"salesforce_tooling_url": field.get("attributes", {}).get("url"),
|
|
36
|
+
"table_id": table_name,
|
|
35
37
|
}
|
|
36
38
|
|
|
37
39
|
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_bigquery.py
RENAMED
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_databricks.py
RENAMED
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_mysql.py
RENAMED
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_postgres.py
RENAMED
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_redshift.py
RENAMED
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_snowflake.py
RENAMED
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_sqlserver.py
RENAMED
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/commands/extract_tableau.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/column_test.py
RENAMED
|
File without changes
|
{castor_extractor-0.18.2 → castor_extractor-0.18.5}/castor_extractor/file_checker/constants.py
RENAMED
|
File without changes
|