castor-extractor 0.16.11__tar.gz → 0.17.0__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.

Files changed (377) hide show
  1. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/CHANGELOG.md +20 -0
  2. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/PKG-INFO +1 -1
  3. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/upload.py +4 -4
  4. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/uploader/constant.py +8 -1
  5. castor_extractor-0.17.0/castor_extractor/uploader/upload.py +133 -0
  6. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/uploader/upload_test.py +4 -3
  7. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/uploader/utils.py +10 -0
  8. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/client/api.py +8 -3
  9. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/retry.py +3 -1
  10. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/client/client.py +5 -2
  11. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/client/gql_queries.py +10 -1
  12. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/abstract/__init__.py +2 -0
  13. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/abstract/asset.py +14 -0
  14. castor_extractor-0.17.0/castor_extractor/warehouse/databricks/client.py +465 -0
  15. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/databricks/client_test.py +61 -1
  16. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/databricks/extract.py +36 -0
  17. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/databricks/format.py +13 -0
  18. castor_extractor-0.17.0/castor_extractor/warehouse/databricks/test_constants.py +79 -0
  19. castor_extractor-0.17.0/castor_extractor/warehouse/databricks/types.py +8 -0
  20. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/extract.py +2 -0
  21. castor_extractor-0.17.0/castor_extractor/warehouse/snowflake/queries/function.sql +10 -0
  22. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/pyproject.toml +1 -1
  23. castor_extractor-0.16.11/castor_extractor/uploader/upload.py +0 -116
  24. castor_extractor-0.16.11/castor_extractor/warehouse/databricks/client.py +0 -229
  25. castor_extractor-0.16.11/castor_extractor/warehouse/databricks/types.py +0 -3
  26. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/Dockerfile +0 -0
  27. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/LICENCE +0 -0
  28. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/README.md +0 -0
  29. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/__init__.py +0 -0
  30. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/__init__.py +0 -0
  31. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_bigquery.py +0 -0
  32. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_databricks.py +0 -0
  33. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_domo.py +0 -0
  34. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_looker.py +0 -0
  35. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_metabase_api.py +0 -0
  36. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_metabase_db.py +0 -0
  37. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_mode.py +0 -0
  38. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_mysql.py +0 -0
  39. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_postgres.py +0 -0
  40. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_powerbi.py +0 -0
  41. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_qlik.py +0 -0
  42. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_redshift.py +0 -0
  43. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_salesforce.py +0 -0
  44. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_salesforce_reporting.py +0 -0
  45. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_sigma.py +0 -0
  46. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_snowflake.py +0 -0
  47. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_sqlserver.py +0 -0
  48. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/extract_tableau.py +0 -0
  49. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/commands/file_check.py +0 -0
  50. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/__init__.py +0 -0
  51. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/column.py +0 -0
  52. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/column_test.py +0 -0
  53. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/constants.py +0 -0
  54. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/enums.py +0 -0
  55. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/file.py +0 -0
  56. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/file_test.py +0 -0
  57. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/file_test_users.csv +0 -0
  58. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/file_test_users_valid.csv +0 -0
  59. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/templates/__init__.py +0 -0
  60. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/file_checker/templates/generic_warehouse.py +0 -0
  61. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/logger.py +0 -0
  62. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/types.py +0 -0
  63. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/uploader/__init__.py +0 -0
  64. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/uploader/env.py +0 -0
  65. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/uploader/env_test.py +0 -0
  66. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/__init__.py +0 -0
  67. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/client/__init__.py +0 -0
  68. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/client/abstract.py +0 -0
  69. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/client/api_test.py +0 -0
  70. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/client/postgres.py +0 -0
  71. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/client/query.py +0 -0
  72. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/client/uri.py +0 -0
  73. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/client/uri_test.py +0 -0
  74. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/collection.py +0 -0
  75. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/collection_test.py +0 -0
  76. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/constants.py +0 -0
  77. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/dbt/__init__.py +0 -0
  78. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/dbt/assets.py +0 -0
  79. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/dbt/client.py +0 -0
  80. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/dbt/client_test.py +0 -0
  81. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/dbt/credentials.py +0 -0
  82. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/deprecate.py +0 -0
  83. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/env.py +0 -0
  84. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/files.py +0 -0
  85. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/files_test.py +0 -0
  86. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/formatter.py +0 -0
  87. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/formatter_test.csv +0 -0
  88. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/formatter_test.json +0 -0
  89. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/formatter_test.py +0 -0
  90. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/json_stream_write.py +0 -0
  91. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/load.py +0 -0
  92. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/object.py +0 -0
  93. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/object_test.py +0 -0
  94. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/pager/__init__.py +0 -0
  95. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/pager/pager.py +0 -0
  96. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/pager/pager_on_id.py +0 -0
  97. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/pager/pager_on_id_test.py +0 -0
  98. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/pager/pager_on_token.py +0 -0
  99. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/pager/pager_on_token_test.py +0 -0
  100. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/pager/pager_test.py +0 -0
  101. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/retry_test.py +0 -0
  102. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/safe.py +0 -0
  103. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/safe_test.py +0 -0
  104. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/salesforce/__init__.py +0 -0
  105. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/salesforce/client.py +0 -0
  106. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/salesforce/client_test.py +0 -0
  107. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/salesforce/constants.py +0 -0
  108. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/salesforce/credentials.py +0 -0
  109. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/salesforce/credentials_test.py +0 -0
  110. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/store.py +0 -0
  111. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/string.py +0 -0
  112. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/string_test.py +0 -0
  113. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/time.py +0 -0
  114. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/time_test.py +0 -0
  115. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/type.py +0 -0
  116. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/validation.py +0 -0
  117. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/validation_test.py +0 -0
  118. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/utils/write.py +0 -0
  119. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/__init__.py +0 -0
  120. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/__init__.py +0 -0
  121. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/assets.py +0 -0
  122. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/client/__init__.py +0 -0
  123. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/client/client.py +0 -0
  124. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/client/client_test.py +0 -0
  125. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/client/credentials.py +0 -0
  126. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/client/endpoints.py +0 -0
  127. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/client/pagination.py +0 -0
  128. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/client/pagination_test.py +0 -0
  129. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/constants.py +0 -0
  130. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/domo/extract.py +0 -0
  131. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/__init__.py +0 -0
  132. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/api/__init__.py +0 -0
  133. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/api/client.py +0 -0
  134. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/api/client_test.py +0 -0
  135. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/api/constants.py +0 -0
  136. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/api/sdk.py +0 -0
  137. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/api/sdk_test.py +0 -0
  138. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/api/utils.py +0 -0
  139. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/assets.py +0 -0
  140. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/constant.py +0 -0
  141. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/env.py +0 -0
  142. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/extract.py +0 -0
  143. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/fields.py +0 -0
  144. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/fields_test.py +0 -0
  145. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/multithreading.py +0 -0
  146. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/looker/parameters.py +0 -0
  147. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/__init__.py +0 -0
  148. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/assets.py +0 -0
  149. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/__init__.py +0 -0
  150. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/api/__init__.py +0 -0
  151. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/api/client.py +0 -0
  152. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/api/client_test.py +0 -0
  153. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/api/credentials.py +0 -0
  154. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/__init__.py +0 -0
  155. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/client.py +0 -0
  156. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/credentials.py +0 -0
  157. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/.sqlfluff +0 -0
  158. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/base_url.sql +0 -0
  159. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/card.sql +0 -0
  160. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/collection.sql +0 -0
  161. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/dashboard.sql +0 -0
  162. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/dashboard_cards.sql +0 -0
  163. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/database.sql +0 -0
  164. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/table.sql +0 -0
  165. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/db/queries/user.sql +0 -0
  166. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/decryption.py +0 -0
  167. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/decryption_test.py +0 -0
  168. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/client/shared.py +0 -0
  169. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/errors.py +0 -0
  170. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/extract.py +0 -0
  171. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/metabase/types.py +0 -0
  172. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/__init__.py +0 -0
  173. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/assets.py +0 -0
  174. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/client/__init__.py +0 -0
  175. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/client/client.py +0 -0
  176. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/client/client_test.json +0 -0
  177. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/client/client_test.py +0 -0
  178. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/client/constants.py +0 -0
  179. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/client/credentials.py +0 -0
  180. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/errors.py +0 -0
  181. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/mode/extract.py +0 -0
  182. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/__init__.py +0 -0
  183. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/assets.py +0 -0
  184. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/client/__init__.py +0 -0
  185. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/client/constants.py +0 -0
  186. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/client/credentials.py +0 -0
  187. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/client/credentials_test.py +0 -0
  188. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/client/rest.py +0 -0
  189. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/client/rest_test.py +0 -0
  190. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/client/utils.py +0 -0
  191. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/client/utils_test.py +0 -0
  192. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/powerbi/extract.py +0 -0
  193. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/__init__.py +0 -0
  194. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/assets.py +0 -0
  195. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/__init__.py +0 -0
  196. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/constants.py +0 -0
  197. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/engine/__init__.py +0 -0
  198. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/engine/client.py +0 -0
  199. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/engine/constants.py +0 -0
  200. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/engine/error.py +0 -0
  201. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/engine/error_test.py +0 -0
  202. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/engine/json_rpc.py +0 -0
  203. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/engine/json_rpc_test.py +0 -0
  204. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/engine/websocket.py +0 -0
  205. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/master.py +0 -0
  206. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/rest.py +0 -0
  207. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/client/rest_test.py +0 -0
  208. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/constants.py +0 -0
  209. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/qlik/extract.py +0 -0
  210. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/salesforce_reporting/__init__.py +0 -0
  211. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/salesforce_reporting/assets.py +0 -0
  212. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/salesforce_reporting/client/__init__.py +0 -0
  213. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/salesforce_reporting/client/rest.py +0 -0
  214. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/salesforce_reporting/client/soql.py +0 -0
  215. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/salesforce_reporting/extract.py +0 -0
  216. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/__init__.py +0 -0
  217. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/assets.py +0 -0
  218. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/client/__init__.py +0 -0
  219. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/client/client.py +0 -0
  220. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/client/client_test.py +0 -0
  221. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/client/credentials.py +0 -0
  222. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/client/endpoints.py +0 -0
  223. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/client/pagination.py +0 -0
  224. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/constants.py +0 -0
  225. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/sigma/extract.py +0 -0
  226. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/__init__.py +0 -0
  227. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/assets.py +0 -0
  228. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/client/__init__.py +0 -0
  229. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/client/client.py +0 -0
  230. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/client/client_utils.py +0 -0
  231. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/client/credentials.py +0 -0
  232. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/client/project.py +0 -0
  233. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/client/safe_mode.py +0 -0
  234. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/constants.py +0 -0
  235. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/errors.py +0 -0
  236. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/extract.py +0 -0
  237. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/gql_fields.py +0 -0
  238. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/__init__.py +0 -0
  239. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/__init__.py +0 -0
  240. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/assets/graphql/metadata/metadata_1_get.json +0 -0
  241. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/assets/graphql/metadata/metadata_2_get.json +0 -0
  242. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/auth.xml +0 -0
  243. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/project_get.xml +0 -0
  244. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/user_get.xml +0 -0
  245. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/view_get_usage.xml +0 -0
  246. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/assets/rest_api/workbook_get.xml +0 -0
  247. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/graphql/__init__.py +0 -0
  248. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/graphql/paginated_object_test.py +0 -0
  249. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/rest_api/__init__.py +0 -0
  250. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/rest_api/auth_test.py +0 -0
  251. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/rest_api/credentials_test.py +0 -0
  252. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/rest_api/projects_test.py +0 -0
  253. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/rest_api/usages_test.py +0 -0
  254. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/rest_api/users_test.py +0 -0
  255. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/rest_api/workbooks_test.py +0 -0
  256. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/utils/__init__.py +0 -0
  257. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tests/unit/utils/env_key.py +0 -0
  258. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/tsc_fields.py +0 -0
  259. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/types.py +0 -0
  260. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau/usage.py +0 -0
  261. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/__init__.py +0 -0
  262. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/assets.py +0 -0
  263. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/client/__init__.py +0 -0
  264. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/client/credentials.py +0 -0
  265. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/client/errors.py +0 -0
  266. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/client/tsc_fields.py +0 -0
  267. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/constants.py +0 -0
  268. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/visualization/tableau_revamp/extract.py +0 -0
  269. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/__init__.py +0 -0
  270. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/abstract/asset_test.py +0 -0
  271. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/abstract/extract.py +0 -0
  272. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/abstract/query.py +0 -0
  273. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/abstract/time_filter.py +0 -0
  274. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/abstract/time_filter_test.py +0 -0
  275. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/__init__.py +0 -0
  276. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/client.py +0 -0
  277. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/client_test.py +0 -0
  278. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/credentials.py +0 -0
  279. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/extract.py +0 -0
  280. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/.sqlfluff +0 -0
  281. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/column.sql +0 -0
  282. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/cte/sharded.sql +0 -0
  283. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/database.sql +0 -0
  284. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/query.sql +0 -0
  285. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/schema.sql +0 -0
  286. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/table.sql +0 -0
  287. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/table_with_tags.sql +0 -0
  288. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/user.sql +0 -0
  289. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/queries/view_ddl.sql +0 -0
  290. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/query.py +0 -0
  291. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/bigquery/types.py +0 -0
  292. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/databricks/__init__.py +0 -0
  293. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/databricks/credentials.py +0 -0
  294. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/databricks/format_test.py +0 -0
  295. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/__init__.py +0 -0
  296. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/client.py +0 -0
  297. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/client_test.py +0 -0
  298. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/extract.py +0 -0
  299. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/queries/.sqlfluff +0 -0
  300. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/queries/column.sql +0 -0
  301. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/queries/database.sql +0 -0
  302. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/queries/query.sql +0 -0
  303. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/queries/schema.sql +0 -0
  304. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/queries/table.sql +0 -0
  305. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/queries/user.sql +0 -0
  306. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/queries/view_ddl.sql +0 -0
  307. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/mysql/query.py +0 -0
  308. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/__init__.py +0 -0
  309. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/extract.py +0 -0
  310. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/queries/.sqlfluff +0 -0
  311. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/queries/column.sql +0 -0
  312. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/queries/database.sql +0 -0
  313. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/queries/group.sql +0 -0
  314. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/queries/schema.sql +0 -0
  315. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/queries/table.sql +0 -0
  316. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/queries/user.sql +0 -0
  317. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/postgres/query.py +0 -0
  318. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/__init__.py +0 -0
  319. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/client.py +0 -0
  320. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/client_test.py +0 -0
  321. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/extract.py +0 -0
  322. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/.sqlfluff +0 -0
  323. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/column.sql +0 -0
  324. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/database.sql +0 -0
  325. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/group.sql +0 -0
  326. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/query.sql +0 -0
  327. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/schema.sql +0 -0
  328. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/table.sql +0 -0
  329. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/table_freshness.sql +0 -0
  330. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/user.sql +0 -0
  331. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/queries/view_ddl.sql +0 -0
  332. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/redshift/query.py +0 -0
  333. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/salesforce/__init__.py +0 -0
  334. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/salesforce/client.py +0 -0
  335. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/salesforce/constants.py +0 -0
  336. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/salesforce/extract.py +0 -0
  337. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/salesforce/format.py +0 -0
  338. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/salesforce/format_test.py +0 -0
  339. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/salesforce/soql.py +0 -0
  340. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/__init__.py +0 -0
  341. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/client.py +0 -0
  342. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/client_test.py +0 -0
  343. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/credentials.py +0 -0
  344. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/credentials_test.py +0 -0
  345. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/.sqlfluff +0 -0
  346. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/column.sql +0 -0
  347. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/column_lineage.sql +0 -0
  348. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/database.sql +0 -0
  349. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/grant_to_role.sql +0 -0
  350. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/grant_to_user.sql +0 -0
  351. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/query.sql +0 -0
  352. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/role.sql +0 -0
  353. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/schema.sql +0 -0
  354. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/table.sql +0 -0
  355. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/user.sql +0 -0
  356. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/queries/view_ddl.sql +0 -0
  357. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/snowflake/query.py +0 -0
  358. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/__init__.py +0 -0
  359. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/client.py +0 -0
  360. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/extract.py +0 -0
  361. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/queries/.sqlfluff +0 -0
  362. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/queries/column.sql +0 -0
  363. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/queries/database.sql +0 -0
  364. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/queries/schema.sql +0 -0
  365. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/queries/table.sql +0 -0
  366. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/queries/user.sql +0 -0
  367. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/sqlserver/query.py +0 -0
  368. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/__init__.py +0 -0
  369. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/extract.py +0 -0
  370. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/queries/.sqlfluff +0 -0
  371. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/queries/column.sql +0 -0
  372. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/queries/database.sql +0 -0
  373. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/queries/query.sql +0 -0
  374. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/queries/schema.sql +0 -0
  375. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/queries/table.sql +0 -0
  376. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/queries/user.sql +0 -0
  377. {castor_extractor-0.16.11 → castor_extractor-0.17.0}/castor_extractor/warehouse/synapse/queries/view_ddl.sql +0 -0
@@ -1,5 +1,25 @@
1
1
  # Changelog
2
2
 
3
+ ## 0.17.0 - 2024-06-10
4
+
5
+ * Uploader: redirect to the proxy, replace credentials with token
6
+
7
+ ## 0.16.15 - 2024-06-07
8
+
9
+ * Tableau: extract database_name for CustomSQLTables
10
+
11
+ ## 0.16.14 - 2024-06-06
12
+
13
+ * Snowflake: Extract SQL user defined function
14
+
15
+ ## 0.16.13 - 2024-06-05
16
+
17
+ * Tableau: extract database_name for tables
18
+
19
+ ## 0.16.12 - 2024-06-04
20
+
21
+ * Databricks: Extract lineage
22
+
3
23
  ## 0.16.11 - 2024-06-03
4
24
 
5
25
  * Tableau: add extra fields to optimise storage
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: castor-extractor
3
- Version: 0.16.11
3
+ Version: 0.17.0
4
4
  Summary: Extract your metadata assets.
5
5
  Home-page: https://www.castordoc.com/
6
6
  License: EULA
@@ -13,10 +13,10 @@ logging.basicConfig(level=logging.INFO, format="%(levelname)s - %(message)s")
13
13
  def _args():
14
14
  parser = argparse.ArgumentParser()
15
15
  parser.add_argument(
16
- "-c",
17
- "--credentials",
16
+ "-k",
17
+ "--token",
18
18
  required=True,
19
- help="""Path to credentials or credentials as string""",
19
+ help="""API token provided by Castor""",
20
20
  )
21
21
  parser.add_argument(
22
22
  "-s",
@@ -44,7 +44,7 @@ def _args():
44
44
  )
45
45
  parsed = parser.parse_args()
46
46
  return {
47
- "credentials": parsed.credentials,
47
+ "token": parsed.token,
48
48
  "source_id": parsed.source_id,
49
49
  "file_path": parsed.file_path,
50
50
  "directory_path": parsed.directory_path,
@@ -1,6 +1,13 @@
1
1
  from enum import Enum
2
2
 
3
- EXTRACTION_BUCKET = "extraction-storage"
3
+ from ..utils import RetryStrategy
4
+
5
+ # url of the gcs proxy
6
+ INGEST_URL = "https://ingest.castordoc.com"
7
+
8
+ RETRY_BASE_MS = 10_000
9
+ RETRY_JITTER_MS = 1_000
10
+ RETRY_STRATEGY = RetryStrategy.LINEAR
4
11
 
5
12
 
6
13
  class FileType(Enum):
@@ -0,0 +1,133 @@
1
+ #!/usr/bin/env python3
2
+ import logging
3
+ import ntpath
4
+ from datetime import datetime
5
+ from typing import Dict, Iterable, Optional, Tuple
6
+ from uuid import UUID
7
+
8
+ import requests
9
+
10
+ from ..utils.retry import retry
11
+ from .constant import (
12
+ INGEST_URL,
13
+ PATH_TEMPLATES,
14
+ RETRY_BASE_MS,
15
+ RETRY_JITTER_MS,
16
+ RETRY_STRATEGY,
17
+ FileType,
18
+ )
19
+ from .env import get_blob_env
20
+ from .utils import iter_files
21
+
22
+ logger = logging.getLogger(__name__)
23
+
24
+ _EXCEPTIONS = (
25
+ requests.exceptions.Timeout,
26
+ requests.exceptions.ConnectTimeout,
27
+ )
28
+
29
+
30
+ def _path_and_url(
31
+ source_id: UUID,
32
+ file_type: FileType,
33
+ file_path: str,
34
+ ) -> Tuple[str, str]:
35
+
36
+ now = datetime.utcnow()
37
+ timestamp = int(now.timestamp())
38
+ filename = ntpath.basename(file_path)
39
+ path_template = PATH_TEMPLATES[file_type]
40
+ path = path_template.format(
41
+ timestamp=timestamp,
42
+ source_id=source_id,
43
+ filename=filename,
44
+ )
45
+
46
+ url = f"{INGEST_URL}/{path}"
47
+
48
+ return path, url
49
+
50
+
51
+ def _headers(token: str) -> Dict:
52
+ return {
53
+ "Authorization": f"Token {token}",
54
+ "Accept": "text/csv, application/json",
55
+ }
56
+
57
+
58
+ def _upload(
59
+ token: str,
60
+ source_id: UUID,
61
+ file_path: str,
62
+ file_type: FileType,
63
+ ) -> None:
64
+ """
65
+ Upload the given file to Google Cloud Storage (GCS)
66
+ - Don't call GCS API directly
67
+ - Call the ingestion proxy which handles authorisation and uploading
68
+ """
69
+ path, url = _path_and_url(source_id, file_type, file_path)
70
+ headers = _headers(token)
71
+ timeout, max_retries = get_blob_env()
72
+
73
+ with open(file_path, "rb") as file_content:
74
+
75
+ @retry(
76
+ exceptions=_EXCEPTIONS,
77
+ max_retries=max_retries,
78
+ base_ms=RETRY_BASE_MS,
79
+ jitter_ms=RETRY_JITTER_MS,
80
+ strategy=RETRY_STRATEGY,
81
+ )
82
+ def _request_post():
83
+ response = requests.post(
84
+ url=url,
85
+ headers=headers,
86
+ data=file_content,
87
+ timeout=timeout,
88
+ )
89
+ response.raise_for_status()
90
+
91
+ _request_post()
92
+
93
+ logger.info(f"Uploaded {file_path} as {file_type.value} to {path}")
94
+
95
+
96
+ def upload_manifest(
97
+ token: str,
98
+ source_id: UUID,
99
+ file_path: str,
100
+ ) -> None:
101
+ """
102
+ credentials: path to file or dict
103
+ source_id: id for the source
104
+ file_path: path to the local manifest to upload
105
+ """
106
+ _upload(token, source_id, file_path, FileType.DBT)
107
+
108
+
109
+ def upload(
110
+ token: str,
111
+ source_id: UUID,
112
+ file_type: FileType,
113
+ file_path: Optional[str] = None,
114
+ directory_path: Optional[str] = None,
115
+ ) -> None:
116
+ """
117
+ credentials: path to file or dict
118
+ source_id: id for the source
119
+ file_type: type of file(s) uploaded - see FileType Enum
120
+ file_path: path to the local visualization or warehouse file to upload
121
+ directory_path: path to the local directory containing files to upload
122
+ """
123
+ files: Iterable[str]
124
+ if directory_path:
125
+ files = iter_files(directory_path)
126
+ elif file_path:
127
+ files = [file_path]
128
+ else:
129
+ message = "either file_path or directory_path should be defined"
130
+ raise ValueError(message)
131
+
132
+ for file_ in files:
133
+ _upload(token, source_id, file_, file_type)
@@ -1,7 +1,7 @@
1
1
  from uuid import UUID
2
2
 
3
- from .constant import FileType
4
- from .upload import _path
3
+ from .constant import INGEST_URL, FileType
4
+ from .upload import _path_and_url
5
5
 
6
6
 
7
7
  def test__path():
@@ -9,5 +9,6 @@ def test__path():
9
9
  file_type = FileType.VIZ
10
10
  file_path = "filename"
11
11
 
12
- path = _path(source_id, file_type, file_path)
12
+ path, url = _path_and_url(source_id, file_type, file_path)
13
13
  assert path == f"visualization-{source_id}/{file_path}"
14
+ assert url == f"{INGEST_URL}/{path}"
@@ -1,13 +1,23 @@
1
+ import logging
1
2
  import os
2
3
  from typing import Iterator
3
4
 
5
+ logger = logging.getLogger(__name__)
6
+
7
+ _ALLOWED_EXTENSION = (".json", ".csv")
8
+
4
9
 
5
10
  def iter_files(repository_path: str) -> Iterator[str]:
6
11
  """
7
12
  Given a repository path yield all files in that repository
13
+ Removes file whose extension is not allowed
8
14
  """
9
15
 
10
16
  for file in os.listdir(repository_path):
17
+ _, ext = os.path.splitext(file)
18
+ if ext not in _ALLOWED_EXTENSION:
19
+ logger.info(f"Forbidden file extension : skipping {file}")
20
+ continue
11
21
  file_path = os.path.join(repository_path, file)
12
22
 
13
23
  if os.path.isfile(file_path):
@@ -5,7 +5,7 @@ import requests
5
5
 
6
6
  logger = logging.getLogger(__name__)
7
7
 
8
- DEFAULT_TIMEOUT_MS = 30_000
8
+ DEFAULT_TIMEOUT_S = 30
9
9
 
10
10
  # https://requests.readthedocs.io/en/latest/api/#requests.request
11
11
  HttpMethod = Literal["GET", "OPTIONS", "HEAD", "POST", "PUT", "PATCH", "DELETE"]
@@ -20,7 +20,7 @@ class APIClient:
20
20
  def __init__(self, host: str, token: Optional[str] = None):
21
21
  self._host = host
22
22
  self._token = token or ""
23
- self._timeout = DEFAULT_TIMEOUT_MS
23
+ self._timeout = DEFAULT_TIMEOUT_S
24
24
 
25
25
  @staticmethod
26
26
  def build_url(host: str, path: str):
@@ -44,7 +44,12 @@ class APIClient:
44
44
  ) -> Any:
45
45
  logger.debug(f"Calling {method} on {url}")
46
46
  result = requests.request(
47
- method, url, headers=self._headers(), params=params, json=data
47
+ method,
48
+ url,
49
+ headers=self._headers(),
50
+ params=params,
51
+ json=data,
52
+ timeout=self._timeout,
48
53
  )
49
54
  result.raise_for_status()
50
55
 
@@ -68,7 +68,8 @@ class Retry(BaseModel):
68
68
  self._retry_attempts += 1
69
69
  wait_ms = self.base() + self.jitter()
70
70
  wait_s = float(wait_ms) / MS_IN_SEC
71
- logger.warning(f"Attempting a new call in {wait_s} seconds")
71
+ msg = f"Attempting a new call in {wait_s} seconds, {self._retry_attempts} attempt(s) / {self.max_retries} max retries"
72
+ logger.warning(msg)
72
73
  time.sleep(wait_s)
73
74
  return True
74
75
 
@@ -93,6 +94,7 @@ def retry(
93
94
  try:
94
95
  return None, callable(*args, **kwargs)
95
96
  except exceptions_ as err:
97
+ logger.warning(f"Exception within {callable.__name__}")
96
98
  return err, None
97
99
 
98
100
  def _func(*args, **kwargs) -> Any:
@@ -31,8 +31,11 @@ _TSC_ASSETS = (
31
31
  # increase the value when extraction is too slow
32
32
  # decrease the value when timeouts arise
33
33
  _CUSTOM_PAGE_SIZE: Dict[TableauRevampAsset, int] = {
34
- # fields and columns are light but volumes are bigger
35
- TableauRevampAsset.COLUMN: 200,
34
+ # for some clients, extraction of columns tend to hit the node limit
35
+ # https://community.tableau.com/s/question/0D54T00000YuK60SAF/metadata-query-nodelimitexceeded-error
36
+ # the workaround is to reduce pagination
37
+ TableauRevampAsset.COLUMN: 50,
38
+ # fields are light but volumes are bigger
36
39
  TableauRevampAsset.FIELD: 1000,
37
40
  TableauRevampAsset.TABLE: 50,
38
41
  }
@@ -63,12 +63,21 @@ downstreamWorkbooks { id }
63
63
  id
64
64
  name
65
65
  ... on DatabaseTable {
66
- connectionType
67
66
  fullName
68
67
  schema
68
+ database {
69
+ connectionType
70
+ id
71
+ name
72
+ }
69
73
  }
70
74
  ... on CustomSQLTable {
71
75
  query
76
+ database {
77
+ connectionType
78
+ id
79
+ name
80
+ }
72
81
  }
73
82
  """
74
83
 
@@ -1,6 +1,8 @@
1
1
  from .asset import (
2
+ ADDITIONAL_LINEAGE_ASSETS,
2
3
  CATALOG_ASSETS,
3
4
  EXTERNAL_LINEAGE_ASSETS,
5
+ FUNCTIONS_ASSETS,
4
6
  QUERIES_ASSETS,
5
7
  VIEWS_ASSETS,
6
8
  SupportedAssets,
@@ -7,6 +7,8 @@ from ...types import ExternalAsset, classproperty
7
7
  class WarehouseAsset(ExternalAsset):
8
8
  """Assets that can be extracted from warehouses"""
9
9
 
10
+ ADDITIONAL_COLUMN_LINEAGE = "additional_column_lineage"
11
+ ADDITIONAL_TABLE_LINEAGE = "additional_table_lineage"
10
12
  COLUMN = "column"
11
13
  COLUMN_LINEAGE = "column_lineage" # specific to snowflake
12
14
  DATABASE = "database"
@@ -19,22 +21,28 @@ class WarehouseAsset(ExternalAsset):
19
21
  ROLE = "role"
20
22
  SCHEMA = "schema"
21
23
  TABLE = "table"
24
+ FUNCTION = "function"
22
25
  USER = "user"
23
26
  VIEW_DDL = "view_ddl"
24
27
 
25
28
  @classproperty
26
29
  def optional(cls) -> Set["WarehouseAsset"]:
27
30
  return {
31
+ WarehouseAsset.ADDITIONAL_COLUMN_LINEAGE,
32
+ WarehouseAsset.ADDITIONAL_TABLE_LINEAGE,
28
33
  WarehouseAsset.EXTERNAL_COLUMN_LINEAGE,
29
34
  WarehouseAsset.EXTERNAL_TABLE_LINEAGE,
35
+ WarehouseAsset.FUNCTION,
30
36
  }
31
37
 
32
38
 
33
39
  class WarehouseAssetGroup(Enum):
34
40
  """Groups of assets that can be extracted together"""
35
41
 
42
+ ADDITIONAL_LINEAGE = "additional_lineage"
36
43
  CATALOG = "catalog"
37
44
  EXTERNAL_LINEAGE = "external_lineage"
45
+ FUNCTION = "function"
38
46
  QUERY = "query"
39
47
  ROLE = "role"
40
48
  SNOWFLAKE_LINEAGE = "snowflake_lineage"
@@ -53,6 +61,7 @@ CATALOG_ASSETS = (
53
61
  )
54
62
 
55
63
  # shared by technologies supporting queries
64
+ FUNCTIONS_ASSETS = (WarehouseAsset.FUNCTION,)
56
65
  QUERIES_ASSETS = (WarehouseAsset.QUERY,)
57
66
  VIEWS_ASSETS = (WarehouseAsset.VIEW_DDL,)
58
67
 
@@ -61,6 +70,11 @@ EXTERNAL_LINEAGE_ASSETS = (
61
70
  WarehouseAsset.EXTERNAL_TABLE_LINEAGE,
62
71
  )
63
72
 
73
+ ADDITIONAL_LINEAGE_ASSETS = (
74
+ WarehouseAsset.ADDITIONAL_COLUMN_LINEAGE,
75
+ WarehouseAsset.ADDITIONAL_TABLE_LINEAGE,
76
+ )
77
+
64
78
  NON_EXTRACTABLE_ASSETS = {WarehouseAssetGroup.EXTERNAL_LINEAGE}
65
79
 
66
80