castor-extractor 0.24.33__tar.gz → 0.24.35__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 (436) hide show
  1. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/CHANGELOG.md +9 -1
  2. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/PKG-INFO +10 -2
  3. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_sqlserver.py +12 -0
  4. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/coalesce/client/client.py +92 -88
  5. castor_extractor-0.24.35/castor_extractor/transformation/coalesce/client/pagination.py +26 -0
  6. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/__init__.py +7 -1
  7. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/pagination.py +5 -2
  8. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/collection.py +26 -0
  9. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/collection_test.py +31 -1
  10. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/queries/query.sql +1 -0
  11. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/client.py +15 -0
  12. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/extract.py +8 -2
  13. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/queries/column.sql +10 -10
  14. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/queries/database.sql +1 -1
  15. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/queries/schema.sql +5 -6
  16. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/queries/table.sql +12 -14
  17. castor_extractor-0.24.35/castor_extractor/warehouse/sqlserver/query.py +53 -0
  18. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/pyproject.toml +1 -1
  19. castor_extractor-0.24.33/castor_extractor/transformation/coalesce/client/type.py +0 -1
  20. castor_extractor-0.24.33/castor_extractor/transformation/coalesce/client/utils.py +0 -52
  21. castor_extractor-0.24.33/castor_extractor/transformation/coalesce/client/utils_test.py +0 -54
  22. castor_extractor-0.24.33/castor_extractor/warehouse/sqlserver/query.py +0 -24
  23. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/Dockerfile +0 -0
  24. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/DockerfileUsage.md +0 -0
  25. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/LICENCE +0 -0
  26. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/README.md +0 -0
  27. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/__init__.py +0 -0
  28. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/__init__.py +0 -0
  29. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_bigquery.py +0 -0
  30. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_confluence.py +0 -0
  31. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_databricks.py +0 -0
  32. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_domo.py +0 -0
  33. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_looker.py +0 -0
  34. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_looker_studio.py +0 -0
  35. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_metabase_api.py +0 -0
  36. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_metabase_db.py +0 -0
  37. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_mode.py +0 -0
  38. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_mysql.py +0 -0
  39. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_notion.py +0 -0
  40. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_postgres.py +0 -0
  41. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_powerbi.py +0 -0
  42. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_qlik.py +0 -0
  43. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_redshift.py +0 -0
  44. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_salesforce.py +0 -0
  45. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_salesforce_reporting.py +0 -0
  46. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_sigma.py +0 -0
  47. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_snowflake.py +0 -0
  48. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_strategy.py +0 -0
  49. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_tableau.py +0 -0
  50. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/extract_thoughtspot.py +0 -0
  51. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/file_check.py +0 -0
  52. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/commands/upload.py +0 -0
  53. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/__init__.py +0 -0
  54. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/column.py +0 -0
  55. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/column_test.py +0 -0
  56. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/constants.py +0 -0
  57. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/enums.py +0 -0
  58. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/file.py +0 -0
  59. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/file_test.py +0 -0
  60. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/file_test_users.csv +0 -0
  61. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/file_test_users_valid.csv +0 -0
  62. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/templates/__init__.py +0 -0
  63. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/file_checker/templates/generic_warehouse.py +0 -0
  64. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/__init__.py +0 -0
  65. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/__init__.py +0 -0
  66. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/assets.py +0 -0
  67. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/client/__init__.py +0 -0
  68. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/client/client.py +0 -0
  69. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/client/client_test.py +0 -0
  70. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/client/credentials.py +0 -0
  71. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/client/endpoints.py +0 -0
  72. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/client/pagination.py +0 -0
  73. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/extract.py +0 -0
  74. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/utils.py +0 -0
  75. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/confluence/utils_test.py +0 -0
  76. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/__init__.py +0 -0
  77. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/assets.py +0 -0
  78. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/client/__init__.py +0 -0
  79. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/client/client.py +0 -0
  80. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/client/client_test.py +0 -0
  81. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/client/constants.py +0 -0
  82. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/client/credentials.py +0 -0
  83. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/client/endpoints.py +0 -0
  84. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/client/pagination.py +0 -0
  85. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/knowledge/notion/extract.py +0 -0
  86. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/logger.py +0 -0
  87. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/quality/__init__.py +0 -0
  88. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/quality/soda/__init__.py +0 -0
  89. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/quality/soda/assets.py +0 -0
  90. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/quality/soda/client/__init__.py +0 -0
  91. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/quality/soda/client/client.py +0 -0
  92. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/quality/soda/client/credentials.py +0 -0
  93. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/quality/soda/client/endpoints.py +0 -0
  94. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/quality/soda/client/pagination.py +0 -0
  95. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/__init__.py +0 -0
  96. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/coalesce/__init__.py +0 -0
  97. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/coalesce/assets.py +0 -0
  98. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/coalesce/client/__init__.py +0 -0
  99. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/coalesce/client/credentials.py +0 -0
  100. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/coalesce/client/endpoint.py +0 -0
  101. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/dbt/__init__.py +0 -0
  102. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/dbt/assets.py +0 -0
  103. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/dbt/client.py +0 -0
  104. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/dbt/client_test.py +0 -0
  105. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/transformation/dbt/credentials.py +0 -0
  106. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/types.py +0 -0
  107. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/uploader/__init__.py +0 -0
  108. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/uploader/constant.py +0 -0
  109. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/uploader/env.py +0 -0
  110. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/uploader/env_test.py +0 -0
  111. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/uploader/settings.py +0 -0
  112. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/uploader/upload.py +0 -0
  113. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/uploader/upload_test.py +0 -0
  114. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/uploader/utils.py +0 -0
  115. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/argument_parser.py +0 -0
  116. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/argument_parser_test.py +0 -0
  117. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/batch.py +0 -0
  118. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/batch_test.py +0 -0
  119. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/__init__.py +0 -0
  120. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/abstract.py +0 -0
  121. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/__init__.py +0 -0
  122. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/auth.py +0 -0
  123. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/auth_test.py +0 -0
  124. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/client.py +0 -0
  125. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/client_test.py +0 -0
  126. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/pagination_test.py +0 -0
  127. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/safe_request.py +0 -0
  128. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/safe_request_test.py +0 -0
  129. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/utils.py +0 -0
  130. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/api/utils_test.py +0 -0
  131. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/postgres.py +0 -0
  132. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/query.py +0 -0
  133. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/uri.py +0 -0
  134. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/client/uri_test.py +0 -0
  135. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/constants.py +0 -0
  136. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/deprecate.py +0 -0
  137. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/env.py +0 -0
  138. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/files.py +0 -0
  139. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/files_test.py +0 -0
  140. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/formatter.py +0 -0
  141. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/formatter_test.csv +0 -0
  142. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/formatter_test.json +0 -0
  143. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/formatter_test.py +0 -0
  144. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/json_stream_write.py +0 -0
  145. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/load.py +0 -0
  146. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/object.py +0 -0
  147. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/object_test.py +0 -0
  148. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/pager/__init__.py +0 -0
  149. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/pager/pager.py +0 -0
  150. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/pager/pager_on_id.py +0 -0
  151. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/pager/pager_on_id_test.py +0 -0
  152. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/pager/pager_test.py +0 -0
  153. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/retry.py +0 -0
  154. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/retry_test.py +0 -0
  155. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/safe.py +0 -0
  156. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/safe_test.py +0 -0
  157. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/salesforce/__init__.py +0 -0
  158. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/salesforce/client.py +0 -0
  159. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/salesforce/client_test.py +0 -0
  160. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/salesforce/constants.py +0 -0
  161. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/salesforce/credentials.py +0 -0
  162. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/salesforce/credentials_test.py +0 -0
  163. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/salesforce/pagination.py +0 -0
  164. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/store.py +0 -0
  165. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/string.py +0 -0
  166. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/string_test.py +0 -0
  167. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/time.py +0 -0
  168. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/time_test.py +0 -0
  169. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/type.py +0 -0
  170. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/url.py +0 -0
  171. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/url_test.py +0 -0
  172. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/validation.py +0 -0
  173. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/validation_test.py +0 -0
  174. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/utils/write.py +0 -0
  175. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/__init__.py +0 -0
  176. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/__init__.py +0 -0
  177. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/assets.py +0 -0
  178. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/client/__init__.py +0 -0
  179. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/client/client.py +0 -0
  180. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/client/credentials.py +0 -0
  181. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/client/endpoints.py +0 -0
  182. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/client/pagination.py +0 -0
  183. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/client/pagination_test.py +0 -0
  184. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/domo/extract.py +0 -0
  185. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/__init__.py +0 -0
  186. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/__init__.py +0 -0
  187. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/client.py +0 -0
  188. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/client_test.py +0 -0
  189. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/constants.py +0 -0
  190. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/credentials.py +0 -0
  191. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/extraction_parameters.py +0 -0
  192. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/sdk.py +0 -0
  193. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/sdk_test.py +0 -0
  194. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/api/utils.py +0 -0
  195. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/assets.py +0 -0
  196. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/constant.py +0 -0
  197. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/constants.py +0 -0
  198. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/extract.py +0 -0
  199. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/fields.py +0 -0
  200. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/fields_test.py +0 -0
  201. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker/multithreading.py +0 -0
  202. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/__init__.py +0 -0
  203. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/assets.py +0 -0
  204. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/__init__.py +0 -0
  205. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/admin_sdk_client.py +0 -0
  206. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/client.py +0 -0
  207. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/credentials.py +0 -0
  208. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/endpoints.py +0 -0
  209. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/enums.py +0 -0
  210. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/looker_studio_api_client.py +0 -0
  211. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/client/pagination.py +0 -0
  212. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/extract.py +0 -0
  213. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/looker_studio/extract_test.py +0 -0
  214. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/__init__.py +0 -0
  215. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/assets.py +0 -0
  216. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/__init__.py +0 -0
  217. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/api/__init__.py +0 -0
  218. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/api/client.py +0 -0
  219. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/api/client_test.py +0 -0
  220. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/api/credentials.py +0 -0
  221. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/__init__.py +0 -0
  222. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/client.py +0 -0
  223. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/credentials.py +0 -0
  224. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/.sqlfluff +0 -0
  225. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/base_url.sql +0 -0
  226. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/card.sql +0 -0
  227. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/collection.sql +0 -0
  228. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/dashboard.sql +0 -0
  229. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/dashboard_cards.sql +0 -0
  230. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/database.sql +0 -0
  231. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/table.sql +0 -0
  232. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/db/queries/user.sql +0 -0
  233. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/decryption.py +0 -0
  234. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/decryption_test.py +0 -0
  235. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/client/shared.py +0 -0
  236. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/errors.py +0 -0
  237. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/extract.py +0 -0
  238. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/metabase/types.py +0 -0
  239. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/__init__.py +0 -0
  240. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/assets.py +0 -0
  241. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/client/__init__.py +0 -0
  242. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/client/client.py +0 -0
  243. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/client/client_test.json +0 -0
  244. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/client/client_test.py +0 -0
  245. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/client/constants.py +0 -0
  246. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/client/credentials.py +0 -0
  247. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/errors.py +0 -0
  248. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/mode/extract.py +0 -0
  249. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/__init__.py +0 -0
  250. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/assets.py +0 -0
  251. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/__init__.py +0 -0
  252. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/authentication.py +0 -0
  253. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/client.py +0 -0
  254. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/client_test.py +0 -0
  255. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/constants.py +0 -0
  256. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/credentials.py +0 -0
  257. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/credentials_test.py +0 -0
  258. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/endpoints.py +0 -0
  259. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/client/pagination.py +0 -0
  260. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/powerbi/extract.py +0 -0
  261. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/__init__.py +0 -0
  262. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/assets.py +0 -0
  263. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/__init__.py +0 -0
  264. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/constants.py +0 -0
  265. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/__init__.py +0 -0
  266. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/client.py +0 -0
  267. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/constants.py +0 -0
  268. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/credentials.py +0 -0
  269. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/error.py +0 -0
  270. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/error_test.py +0 -0
  271. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/json_rpc.py +0 -0
  272. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/json_rpc_test.py +0 -0
  273. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/engine/websocket.py +0 -0
  274. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/master.py +0 -0
  275. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/rest.py +0 -0
  276. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/client/rest_test.py +0 -0
  277. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/qlik/extract.py +0 -0
  278. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/salesforce_reporting/__init__.py +0 -0
  279. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/salesforce_reporting/assets.py +0 -0
  280. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/salesforce_reporting/client/__init__.py +0 -0
  281. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/salesforce_reporting/client/rest.py +0 -0
  282. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/salesforce_reporting/client/soql.py +0 -0
  283. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/salesforce_reporting/extract.py +0 -0
  284. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/__init__.py +0 -0
  285. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/assets.py +0 -0
  286. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/client/__init__.py +0 -0
  287. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/client/client.py +0 -0
  288. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/client/client_test.py +0 -0
  289. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/client/credentials.py +0 -0
  290. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/client/endpoints.py +0 -0
  291. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/client/pagination.py +0 -0
  292. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/sigma/extract.py +0 -0
  293. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/strategy/__init__.py +0 -0
  294. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/strategy/assets.py +0 -0
  295. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/strategy/client/__init__.py +0 -0
  296. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/strategy/client/client.py +0 -0
  297. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/strategy/client/credentials.py +0 -0
  298. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/strategy/client/properties.py +0 -0
  299. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/strategy/extract.py +0 -0
  300. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/__init__.py +0 -0
  301. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/assets.py +0 -0
  302. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/__init__.py +0 -0
  303. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/client.py +0 -0
  304. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/client_metadata_api.py +0 -0
  305. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/client_metadata_api_test.py +0 -0
  306. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/client_rest_api.py +0 -0
  307. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/client_tsc.py +0 -0
  308. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/credentials.py +0 -0
  309. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/errors.py +0 -0
  310. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/gql_queries.py +0 -0
  311. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/client/rest_fields.py +0 -0
  312. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/constants.py +0 -0
  313. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/tableau/extract.py +0 -0
  314. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/thoughtspot/__init__.py +0 -0
  315. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/thoughtspot/assets.py +0 -0
  316. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/thoughtspot/client/__init__.py +0 -0
  317. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/thoughtspot/client/client.py +0 -0
  318. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/thoughtspot/client/credentials.py +0 -0
  319. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/thoughtspot/client/endpoints.py +0 -0
  320. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/thoughtspot/client/pagination.py +0 -0
  321. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/visualization/thoughtspot/extract.py +0 -0
  322. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/__init__.py +0 -0
  323. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/abstract/__init__.py +0 -0
  324. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/abstract/asset.py +0 -0
  325. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/abstract/asset_test.py +0 -0
  326. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/abstract/extract.py +0 -0
  327. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/abstract/query.py +0 -0
  328. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/abstract/time_filter.py +0 -0
  329. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/abstract/time_filter_test.py +0 -0
  330. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/__init__.py +0 -0
  331. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/client.py +0 -0
  332. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/client_test.py +0 -0
  333. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/credentials.py +0 -0
  334. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/extract.py +0 -0
  335. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/.sqlfluff +0 -0
  336. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/column.sql +0 -0
  337. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/cte/sharded.sql +0 -0
  338. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/database.sql +0 -0
  339. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/query.sql +0 -0
  340. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/schema.sql +0 -0
  341. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/table.sql +0 -0
  342. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/table_with_tags.sql +0 -0
  343. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/user.sql +0 -0
  344. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/queries/view_ddl.sql +0 -0
  345. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/query.py +0 -0
  346. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/bigquery/types.py +0 -0
  347. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/__init__.py +0 -0
  348. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/api_client.py +0 -0
  349. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/api_client_test.py +0 -0
  350. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/client.py +0 -0
  351. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/client_test.py +0 -0
  352. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/credentials.py +0 -0
  353. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/endpoints.py +0 -0
  354. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/enums.py +0 -0
  355. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/extract.py +0 -0
  356. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/format.py +0 -0
  357. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/format_test.py +0 -0
  358. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/lineage.py +0 -0
  359. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/lineage_test.py +0 -0
  360. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/pagination.py +0 -0
  361. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/sql_client.py +0 -0
  362. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/types.py +0 -0
  363. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/utils.py +0 -0
  364. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/databricks/utils_test.py +0 -0
  365. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/__init__.py +0 -0
  366. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/client.py +0 -0
  367. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/client_test.py +0 -0
  368. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/extract.py +0 -0
  369. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/queries/.sqlfluff +0 -0
  370. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/queries/column.sql +0 -0
  371. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/queries/database.sql +0 -0
  372. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/queries/query.sql +0 -0
  373. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/queries/schema.sql +0 -0
  374. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/queries/table.sql +0 -0
  375. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/queries/user.sql +0 -0
  376. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/queries/view_ddl.sql +0 -0
  377. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/mysql/query.py +0 -0
  378. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/__init__.py +0 -0
  379. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/extract.py +0 -0
  380. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/queries/.sqlfluff +0 -0
  381. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/queries/column.sql +0 -0
  382. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/queries/database.sql +0 -0
  383. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/queries/group.sql +0 -0
  384. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/queries/schema.sql +0 -0
  385. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/queries/table.sql +0 -0
  386. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/queries/user.sql +0 -0
  387. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/postgres/query.py +0 -0
  388. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/__init__.py +0 -0
  389. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/client.py +0 -0
  390. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/client_test.py +0 -0
  391. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/extract.py +0 -0
  392. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/extract_test.py +0 -0
  393. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/.sqlfluff +0 -0
  394. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/column.sql +0 -0
  395. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/database.sql +0 -0
  396. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/group.sql +0 -0
  397. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/query.sql +0 -0
  398. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/query_serverless.sql +0 -0
  399. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/schema.sql +0 -0
  400. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/table.sql +0 -0
  401. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/table_freshness.sql +0 -0
  402. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/user.sql +0 -0
  403. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/queries/view_ddl.sql +0 -0
  404. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/redshift/query.py +0 -0
  405. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/salesforce/__init__.py +0 -0
  406. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/salesforce/client.py +0 -0
  407. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/salesforce/constants.py +0 -0
  408. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/salesforce/extract.py +0 -0
  409. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/salesforce/format.py +0 -0
  410. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/salesforce/format_test.py +0 -0
  411. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/salesforce/pagination.py +0 -0
  412. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/salesforce/soql.py +0 -0
  413. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/__init__.py +0 -0
  414. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/client.py +0 -0
  415. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/client_test.py +0 -0
  416. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/credentials.py +0 -0
  417. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/credentials_test.py +0 -0
  418. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/extract.py +0 -0
  419. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/.sqlfluff +0 -0
  420. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/column.sql +0 -0
  421. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/column_lineage.sql +0 -0
  422. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/database.sql +0 -0
  423. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/function.sql +0 -0
  424. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/grant_to_role.sql +0 -0
  425. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/grant_to_user.sql +0 -0
  426. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/query.sql +0 -0
  427. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/role.sql +0 -0
  428. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/schema.sql +0 -0
  429. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/table.sql +0 -0
  430. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/user.sql +0 -0
  431. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/queries/view_ddl.sql +0 -0
  432. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/snowflake/query.py +0 -0
  433. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/__init__.py +0 -0
  434. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/queries/.sqlfluff +0 -0
  435. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/sqlserver/queries/user.sql +0 -0
  436. {castor_extractor-0.24.33 → castor_extractor-0.24.35}/castor_extractor/warehouse/synapse/queries/column.sql +0 -0
@@ -1,5 +1,13 @@
1
1
  # Changelog
2
2
 
3
+ ## 0.24.35 - 2025-07-29
4
+
5
+ * Coalesce - Fix pagination issue
6
+
7
+ ## 0.24.34 - 2025-07-02
8
+
9
+ * SQLServer: multiple databases
10
+
3
11
  ## 0.24.33 - 2025-07-10
4
12
 
5
13
  * Tableau - Add an option to skip fields ingestion
@@ -10,7 +18,7 @@
10
18
 
11
19
  ## 0.24.31 - 2025-07-02
12
20
 
13
- * Looker Studio: add option to list users via a provided JSON file
21
+ * Looker Studio: add an option to list users via a provided JSON file
14
22
 
15
23
  ## 0.24.30 - 2025-06-26
16
24
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: castor-extractor
3
- Version: 0.24.33
3
+ Version: 0.24.35
4
4
  Summary: Extract your metadata assets.
5
5
  Home-page: https://www.castordoc.com/
6
6
  License: EULA
@@ -215,6 +215,14 @@ For any questions or bug report, contact us at [support@coalesce.io](mailto:supp
215
215
 
216
216
  # Changelog
217
217
 
218
+ ## 0.24.35 - 2025-07-29
219
+
220
+ * Coalesce - Fix pagination issue
221
+
222
+ ## 0.24.34 - 2025-07-02
223
+
224
+ * SQLServer: multiple databases
225
+
218
226
  ## 0.24.33 - 2025-07-10
219
227
 
220
228
  * Tableau - Add an option to skip fields ingestion
@@ -225,7 +233,7 @@ For any questions or bug report, contact us at [support@coalesce.io](mailto:supp
225
233
 
226
234
  ## 0.24.31 - 2025-07-02
227
235
 
228
- * Looker Studio: add option to list users via a provided JSON file
236
+ * Looker Studio: add an option to list users via a provided JSON file
229
237
 
230
238
  ## 0.24.30 - 2025-06-26
231
239
 
@@ -23,6 +23,16 @@ def main():
23
23
  action="store_true",
24
24
  help="Skips files already extracted instead of replacing them",
25
25
  )
26
+ parser.add_argument(
27
+ "--db-allowed",
28
+ nargs="*",
29
+ help="List of databases that should be extracted",
30
+ )
31
+ parser.add_argument(
32
+ "--db-blocked",
33
+ nargs="*",
34
+ help="List of databases that should not be extracted",
35
+ )
26
36
  parser.set_defaults(skip_existing=False)
27
37
 
28
38
  args = parser.parse_args()
@@ -35,4 +45,6 @@ def main():
35
45
  password=args.password,
36
46
  output_directory=args.output,
37
47
  skip_existing=args.skip_existing,
48
+ db_allowed=args.db_allowed,
49
+ db_blocked=args.db_blocked,
38
50
  )
@@ -1,31 +1,47 @@
1
1
  import logging
2
+ from functools import partial
2
3
  from http import HTTPStatus
3
- from typing import Iterator, Optional
4
+ from typing import Callable, Optional
4
5
 
5
- from requests import ConnectionError
6
+ from pydantic import ValidationError
6
7
 
7
8
  from ....utils import (
8
9
  APIClient,
9
10
  BearerAuth,
10
11
  RequestSafeMode,
11
12
  SerializedAsset,
13
+ fetch_all_pages,
12
14
  )
13
15
  from ..assets import CoalesceAsset, CoalesceQualityAsset
14
16
  from .credentials import CoalesceCredentials
15
17
  from .endpoint import (
16
18
  CoalesceEndpointFactory,
17
19
  )
18
- from .type import NodeIDToNamesMapping
19
- from .utils import column_names_per_node, is_test, test_names_per_node
20
+ from .pagination import CoalescePagination
21
+
22
+ logger = logging.getLogger(__name__)
23
+
24
+
25
+ COALESCE_PAGE_SIZE = 300
26
+ COALESCE_PAGE_SIZE_RUN_RESULTS = 1_000
27
+
28
+ COALESCE_TIMEOUT_SECONDS = 90
20
29
 
21
- _LIMIT_MAX = 1_000
22
30
  _MAX_ERRORS = 200
23
31
 
24
- logger = logging.getLogger(__name__)
32
+ COALESCE_SAFE_MODE = RequestSafeMode(
33
+ status_codes=(HTTPStatus.INTERNAL_SERVER_ERROR,),
34
+ max_errors=_MAX_ERRORS,
35
+ )
25
36
 
26
37
 
27
- def _run_result_payload(result: dict, query_result: dict) -> dict:
38
+ def _run_result_payload(
39
+ environment_id: str,
40
+ result: dict,
41
+ query_result: dict,
42
+ ) -> dict:
28
43
  return {
44
+ "environment_id": environment_id,
29
45
  "node_id": result["nodeID"],
30
46
  "node_name": result["name"],
31
47
  "test_name": query_result["name"],
@@ -37,13 +53,6 @@ def _run_result_payload(result: dict, query_result: dict) -> dict:
37
53
  }
38
54
 
39
55
 
40
- COALESCE_SAFE_MODE = RequestSafeMode(
41
- status_codes=(HTTPStatus.INTERNAL_SERVER_ERROR,),
42
- max_errors=_MAX_ERRORS,
43
- )
44
- COALESCE_TIMEOUT_SECONDS = 90
45
-
46
-
47
56
  class CoalesceBearerAuth(BearerAuth):
48
57
  """Bearer Authentication for Coalesce"""
49
58
 
@@ -69,65 +78,74 @@ class CoalesceClient(APIClient):
69
78
  timeout=COALESCE_TIMEOUT_SECONDS,
70
79
  )
71
80
 
72
- def _fetch_environments(self) -> Iterator[dict]:
73
- endpoint = CoalesceEndpointFactory.environments()
74
- result = self._get(endpoint=endpoint)
75
- return result["data"]
76
-
77
- def _node_details(self, environment_id: int, node_id: str) -> dict:
78
- endpoint = CoalesceEndpointFactory.nodes(
79
- environment_id=environment_id, node_id=node_id
81
+ def _get_paginated(
82
+ self,
83
+ endpoint: str,
84
+ limit: int = COALESCE_PAGE_SIZE,
85
+ params: Optional[dict] = None,
86
+ ) -> Callable:
87
+ return partial(
88
+ self._get,
89
+ retry_on_timeout=False, # explained in the docstring
90
+ endpoint=endpoint,
91
+ params={
92
+ "limit": limit,
93
+ **(params or dict()),
94
+ },
80
95
  )
81
- return self._get(endpoint=endpoint)
96
+
97
+ def _fetch_environments(self) -> SerializedAsset:
98
+ endpoint = CoalesceEndpointFactory.environments()
99
+ request = self._get_paginated(endpoint=endpoint)
100
+ result = fetch_all_pages(request, CoalescePagination)
101
+ return list(result)
82
102
 
83
103
  def _fetch_env_nodes(self, environment_id: int) -> SerializedAsset:
84
104
  endpoint = CoalesceEndpointFactory.nodes(environment_id=environment_id)
85
- result = self._get(endpoint=endpoint)
86
- nodes: list[dict] = []
87
- for node in result["data"]:
88
- try:
89
- details = self._node_details(environment_id, node["id"])
90
- nodes.append({**node, **details})
91
- except ConnectionError as e:
92
- node_id = node["id"]
93
- message = f"ConnectionError, environment: {environment_id}, node: {node_id}"
94
- logger.warning(message)
95
- raise e
96
- return nodes
105
+ request = self._get_paginated(
106
+ endpoint=endpoint,
107
+ params={"detail": "true"},
108
+ )
109
+ result = fetch_all_pages(request, CoalescePagination)
110
+ return [
111
+ {
112
+ **node,
113
+ "environment_id": environment_id,
114
+ }
115
+ for node in result
116
+ ]
97
117
 
98
118
  def _fetch_all_nodes(self) -> SerializedAsset:
119
+ environments = self._fetch_environments()
120
+ total = len(environments)
99
121
  nodes: list[dict] = []
100
- for environment in self._fetch_environments():
101
- environment_id = environment["id"]
102
- nodes.extend(self._fetch_env_nodes(environment_id))
122
+
123
+ for index, env in enumerate(environments):
124
+ env_id = env["id"]
125
+ logger.info(f"Fetching nodes for env #{env_id} - {index}/{total}")
126
+ try:
127
+ nodes.extend(self._fetch_env_nodes(env_id))
128
+ except ValidationError as e:
129
+ # 500 Server Error: Internal Server Error on Coalesce API
130
+ logger.warning(
131
+ f"Skipping nodes for {env_id} due to the following Error: {e}"
132
+ )
133
+ logger.info(f"{len(nodes)} nodes extracted so far")
103
134
  return nodes
104
135
 
105
136
  def _fetch_runs(self, starting_from: str) -> SerializedAsset:
106
- """
107
- fetch runs, per environment;
108
- we break per environment to lower the chance of exceeding the 1k limit
109
- """
110
- runs: list[dict] = []
111
- for environment in self._fetch_environments():
112
- environment_id = environment["id"]
113
- runs.extend(
114
- self._fetch_recent_runs_per_env(environment_id, starting_from)
115
- )
116
- return runs
117
-
118
- def _fetch_recent_runs_per_env(
119
- self, environment_id: int, starting_from: str
120
- ) -> SerializedAsset:
121
137
  endpoint = CoalesceEndpointFactory.runs()
122
138
  params = {
123
- "environmentID": environment_id,
124
- "limit": _LIMIT_MAX,
125
139
  "orderBy": "runEndTime",
126
140
  "orderByDirection": "asc",
127
141
  "startingFrom": starting_from,
128
142
  }
129
- result = self._get(endpoint=endpoint, params=params)
130
- return result["data"]
143
+ request = self._get_paginated(
144
+ endpoint=endpoint,
145
+ params=params,
146
+ limit=COALESCE_PAGE_SIZE_RUN_RESULTS,
147
+ )
148
+ return list(fetch_all_pages(request, CoalescePagination))
131
149
 
132
150
  def _fetch_run_results(self, run_id: str) -> SerializedAsset:
133
151
  endpoint = CoalesceEndpointFactory.run_results(run_id)
@@ -136,51 +154,37 @@ class CoalesceClient(APIClient):
136
154
 
137
155
  def _run_results_by_run(
138
156
  self,
157
+ environment_id: str,
139
158
  run_id: str,
140
- test_names: NodeIDToNamesMapping,
141
- column_names: NodeIDToNamesMapping,
142
159
  ) -> SerializedAsset:
143
160
  run_results: list[dict] = []
144
161
  for result in self._fetch_run_results(run_id):
145
- node_id = result["nodeID"]
146
162
  for query_result in result["queryResults"]:
147
- _is_test = is_test(
163
+ if query_result["type"] != "sqlTest":
164
+ continue
165
+ run_result = _run_result_payload(
166
+ environment_id,
167
+ result,
148
168
  query_result,
149
- node_id,
150
- test_names,
151
- column_names,
152
169
  )
153
- if not _is_test:
154
- continue
155
- run_result = _run_result_payload(result, query_result)
156
170
  run_results.append(run_result)
157
171
  return run_results
158
172
 
159
- def _run_results_by_env(
160
- self, environment_id: int, starting_from: str
173
+ def _fetch_all_run_results(
174
+ self,
175
+ starting_from: str,
161
176
  ) -> SerializedAsset:
162
177
  run_results: list[dict] = []
163
- nodes = self._fetch_env_nodes(environment_id)
164
- test_names = test_names_per_node(nodes)
165
- column_names = column_names_per_node(nodes)
166
- runs = self._fetch_recent_runs_per_env(environment_id, starting_from)
167
178
 
168
- for run in runs:
169
- run_id = run["id"]
170
- _results = self._run_results_by_run(
171
- run_id, test_names, column_names
172
- )
173
- run_results.extend(_results)
174
- return run_results
175
-
176
- def _fetch_all_run_results(self, starting_from: str) -> SerializedAsset:
177
- run_results: list[dict] = []
178
-
179
- for environment in self._fetch_environments():
180
- environment_id = environment["id"]
181
- _results = self._run_results_by_env(environment_id, starting_from)
182
- run_results.extend(_results)
179
+ runs = self._fetch_runs(starting_from)
180
+ total = len(runs)
183
181
 
182
+ for index, run in enumerate(runs):
183
+ logger.info(f"Extracting run results ({index}/{total})")
184
+ run_id = run["id"]
185
+ environment_id = run["environmentID"]
186
+ current_results = self._run_results_by_run(environment_id, run_id)
187
+ run_results.extend(current_results)
184
188
  return run_results
185
189
 
186
190
  def fetch(
@@ -0,0 +1,26 @@
1
+ from typing import Optional, Union
2
+
3
+ from ....utils import PaginationModel
4
+
5
+
6
+ class CoalescePagination(PaginationModel):
7
+ """
8
+ Class to handle paginated results for Coalesce
9
+ See their documentation here
10
+ https://docs.coalesce.io/docs/api
11
+ """
12
+
13
+ data: list
14
+ next: Union[Optional[str], Optional[int]] = None
15
+
16
+ def is_last(self) -> bool:
17
+ """Stopping condition for the pagination"""
18
+ return self.next is None
19
+
20
+ def next_page_payload(self):
21
+ """Payload enabling to generate the request for the next page"""
22
+ return {"startingFrom": self.next}
23
+
24
+ def page_results(self) -> list:
25
+ """List of results of the current page"""
26
+ return self.data
@@ -19,7 +19,13 @@ from .client import (
19
19
  handle_response,
20
20
  uri_encode,
21
21
  )
22
- from .collection import deduplicate, empty_iterator, group_by, mapping_from_rows
22
+ from .collection import (
23
+ deduplicate,
24
+ empty_iterator,
25
+ filter_items,
26
+ group_by,
27
+ mapping_from_rows,
28
+ )
23
29
  from .constants import OUTPUT_DIR
24
30
  from .deprecate import deprecate_python
25
31
  from .env import from_env
@@ -66,16 +66,19 @@ def fetch_all_pages(
66
66
  """
67
67
  page_number = 1
68
68
  response_payload = request()
69
+
69
70
  paginated_response = pagination_model(**response_payload)
71
+
70
72
  while not paginated_response.is_last():
71
73
  logger.debug(f"Fetching page number {page_number}")
72
74
  yield from paginated_response.page_results()
73
75
  next_page_parameters = paginated_response.next_page_parameters()
74
- new_request = partial(request, **next_page_parameters)
76
+ request_with_pagination = partial(request, **next_page_parameters)
75
77
  if rate_limit:
76
78
  sleep(rate_limit)
77
79
  paginated_response = pagination_model(
78
- current_page_payload=next_page_parameters, **new_request()
80
+ current_page_payload=next_page_parameters,
81
+ **request_with_pagination(),
79
82
  )
80
83
  page_number += 1
81
84
 
@@ -2,6 +2,8 @@ from collections import defaultdict
2
2
  from collections.abc import Iterable, Sequence
3
3
  from typing import (
4
4
  Any,
5
+ List,
6
+ Optional,
5
7
  TypeVar,
6
8
  )
7
9
 
@@ -80,3 +82,27 @@ def deduplicate(
80
82
  deduplicated.append(element)
81
83
 
82
84
  return deduplicated
85
+
86
+
87
+ def filter_items(
88
+ items: Iterable[T],
89
+ allowed: Optional[Iterable[T]] = None,
90
+ blocked: Optional[Iterable[T]] = None,
91
+ ) -> List[T]:
92
+ """
93
+ Filters `items` by excluding any in `blocked` or including only those in `allowed`.
94
+ If both `allowed` and `blocked` are None, returns all items.
95
+ If both are provided, raise an error.
96
+ """
97
+ items = list(items)
98
+
99
+ if allowed and blocked:
100
+ raise AttributeError(
101
+ "Only one of `allowed` and `blocked` can be provided"
102
+ )
103
+ if blocked:
104
+ return [item for item in items if item not in blocked]
105
+ if allowed:
106
+ return [item for item in items if item in allowed]
107
+
108
+ return items
@@ -1,4 +1,6 @@
1
- from .collection import deduplicate, mapping_from_rows
1
+ import pytest
2
+
3
+ from .collection import deduplicate, filter_items, mapping_from_rows
2
4
 
3
5
 
4
6
  def test__mapping_from_rows__basic_mapping():
@@ -72,3 +74,31 @@ def test_deduplicate():
72
74
  {"id": "2", "name": "duplicate"},
73
75
  ]
74
76
  assert deduplicate("id", elements) == [e1, e2, e3]
77
+
78
+
79
+ def test_sqlserver_databases():
80
+ databases = [
81
+ "prod",
82
+ "staging",
83
+ "test",
84
+ ]
85
+
86
+ # 1. No allowed or blocked: should return all
87
+ result1 = filter_items(databases)
88
+ assert result1 == [
89
+ "prod",
90
+ "staging",
91
+ "test",
92
+ ]
93
+
94
+ # 2. Block "prod": only staging and test should remain
95
+ result2 = filter_items(databases, blocked=["prod"])
96
+ assert result2 == ["staging", "test"]
97
+
98
+ # 3. Only allow "staging" and "test"
99
+ result3 = filter_items(databases, allowed=["staging", "test"])
100
+ assert result3 == ["staging", "test"]
101
+
102
+ # 4. allowed and blocked, should raise
103
+ with pytest.raises(AttributeError):
104
+ filter_items(databases, blocked=["prod"], allowed=["staging", "test"])
@@ -29,6 +29,7 @@ WITH ranked_by_datasource AS (
29
29
  `{project}.region-{region}.INFORMATION_SCHEMA.JOBS_BY_PROJECT`
30
30
  WHERE
31
31
  job_type = 'QUERY'
32
+ AND ARRAY_LENGTH(referenced_tables) > 0
32
33
  AND EXISTS (
33
34
  SELECT
34
35
  1
@@ -1,15 +1,20 @@
1
+ import logging
1
2
  from collections.abc import Iterator
2
3
 
3
4
  from sqlalchemy import text
4
5
 
5
6
  from ...utils import ExtractionQuery, SqlalchemyClient, uri_encode
6
7
 
8
+ logger = logging.getLogger(__name__)
9
+
7
10
  SERVER_URI = "{user}:{password}@{host}:{port}/{database}"
8
11
  MSSQL_URI = f"mssql+pymssql://{SERVER_URI}"
9
12
  DEFAULT_PORT = 1433
10
13
 
11
14
  _KEYS = ("user", "password", "host", "port", "database")
12
15
 
16
+ _SYSTEM_DATABASES = ("master", "model", "msdb", "tempdb", "DBAdmin")
17
+
13
18
 
14
19
  def _check_key(credentials: dict) -> None:
15
20
  for key in _KEYS:
@@ -51,3 +56,13 @@ class MSSQLClient(SqlalchemyClient):
51
56
  yield from results
52
57
  finally:
53
58
  self.close()
59
+
60
+ def get_databases(self) -> list[str]:
61
+ result = self.execute(
62
+ ExtractionQuery("SELECT name FROM sys.databases", {})
63
+ )
64
+ return [
65
+ row["name"]
66
+ for row in result
67
+ if row["name"] not in _SYSTEM_DATABASES
68
+ ]
@@ -1,6 +1,6 @@
1
1
  import logging
2
2
 
3
- from ...utils import LocalStorage, from_env, write_summary
3
+ from ...utils import LocalStorage, filter_items, from_env, write_summary
4
4
  from ..abstract import (
5
5
  CATALOG_ASSETS,
6
6
  EXTERNAL_LINEAGE_ASSETS,
@@ -51,7 +51,13 @@ def extract_all(**kwargs) -> None:
51
51
 
52
52
  client = MSSQLClient(credentials=_credentials(kwargs))
53
53
 
54
- query_builder = MSSQLQueryBuilder()
54
+ databases = filter_items(
55
+ client.get_databases(), kwargs.get("allowed"), kwargs.get("blocked")
56
+ )
57
+
58
+ query_builder = MSSQLQueryBuilder(
59
+ databases=databases,
60
+ )
55
61
 
56
62
  storage = LocalStorage(directory=output_directory)
57
63
 
@@ -11,7 +11,7 @@ WITH extended_tables AS (
11
11
  table_owner_id = principal_id,
12
12
  schema_id
13
13
  FROM
14
- sys.tables
14
+ {database}.sys.tables
15
15
 
16
16
  UNION
17
17
 
@@ -21,7 +21,7 @@ WITH extended_tables AS (
21
21
  table_owner_id = principal_id,
22
22
  schema_id
23
23
  FROM
24
- sys.views
24
+ {database}.sys.views
25
25
 
26
26
  UNION
27
27
 
@@ -31,7 +31,7 @@ WITH extended_tables AS (
31
31
  table_owner_id = principal_id,
32
32
  schema_id
33
33
  FROM
34
- sys.external_tables
34
+ {database}.sys.external_tables
35
35
  ),
36
36
  /*
37
37
  `sys.columns` contains, among others:
@@ -54,11 +54,11 @@ column_ids AS (
54
54
  schema_name = ss.name,
55
55
  schema_id = ss.schema_id,
56
56
  comment = CONVERT(varchar(1024), ep.value)
57
- FROM sys.columns AS sc
57
+ FROM {database}.sys.columns AS sc
58
58
  LEFT JOIN extended_tables AS et ON sc.object_id = et.table_id
59
- LEFT JOIN sys.schemas AS ss ON et.schema_id = ss.schema_id
60
- LEFT JOIN sys.databases AS sd ON sd.name = DB_NAME()
61
- LEFT JOIN sys.extended_properties AS ep
59
+ LEFT JOIN {database}.sys.schemas AS ss ON et.schema_id = ss.schema_id
60
+ LEFT JOIN {database}.sys.databases AS sd ON sd.name = '{database}'
61
+ LEFT JOIN {database}.sys.extended_properties AS ep
62
62
  ON
63
63
  sc.object_id = ep.major_id
64
64
  AND sc.column_id = ep.minor_id
@@ -70,9 +70,9 @@ columns AS (
70
70
  i.database_name,
71
71
  i.database_id,
72
72
  schema_name = c.table_schema,
73
- i.schema_id,
73
+ schema_id = CAST(i.database_id AS VARCHAR(10)) + '_' + CAST(i.schema_id AS VARCHAR(10)),
74
74
  table_name = c.table_name,
75
- i.table_id,
75
+ table_id = CAST(i.database_id AS VARCHAR(10)) + '_' + CAST(i.schema_id AS VARCHAR(10)) + '_' + CAST(i.table_id AS VARCHAR(10)),
76
76
  c.column_name,
77
77
  c.data_type,
78
78
  c.ordinal_position,
@@ -87,7 +87,7 @@ columns AS (
87
87
  i.comment,
88
88
  column_id = CONCAT(i.table_id, '.', c.column_name)
89
89
  FROM
90
- information_schema.columns AS c
90
+ {database}.information_schema.columns AS c
91
91
  LEFT JOIN column_ids AS i
92
92
  ON
93
93
  (
@@ -2,4 +2,4 @@ SELECT
2
2
  db.database_id,
3
3
  database_name = db.name
4
4
  FROM sys.databases AS db
5
- WHERE db.name = DB_NAME()
5
+ WHERE db.name NOT IN ('master', 'model', 'msdb', 'tempdb', 'DBAdmin');
@@ -3,21 +3,20 @@ WITH ids AS (
3
3
  SELECT DISTINCT
4
4
  table_catalog,
5
5
  table_schema
6
- FROM information_schema.tables
7
- WHERE table_catalog = DB_NAME()
6
+ FROM {database}.information_schema.tables
8
7
  )
9
8
 
10
9
  SELECT
11
10
  d.database_id,
12
11
  database_name = i.table_catalog,
13
12
  schema_name = s.name,
14
- s.schema_id,
13
+ schema_id = CAST(d.database_id AS VARCHAR(10)) + '_' + CAST(s.schema_id AS VARCHAR(10)),
15
14
  schema_owner = u.name,
16
15
  schema_owner_id = u.uid
17
- FROM sys.schemas AS s
16
+ FROM {database}.sys.schemas AS s
18
17
  INNER JOIN ids AS i
19
18
  ON s.name = i.table_schema
20
- LEFT JOIN sys.sysusers AS u
19
+ LEFT JOIN {database}.sys.sysusers AS u
21
20
  ON s.principal_id = u.uid
22
- LEFT JOIN sys.databases AS d
21
+ LEFT JOIN {database}.sys.databases AS d
23
22
  ON i.table_catalog = d.name