castor-extractor 0.24.38__tar.gz → 0.24.40__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 (437) hide show
  1. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/CHANGELOG.md +10 -0
  2. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/PKG-INFO +11 -1
  3. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/client.py +2 -1
  4. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/client.py +4 -5
  5. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/client_test.py +2 -1
  6. castor_extractor-0.24.40/castor_extractor/warehouse/databricks/queries/column_lineage.sql +25 -0
  7. castor_extractor-0.24.40/castor_extractor/warehouse/databricks/queries/table_lineage.sql +23 -0
  8. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/sql_client.py +14 -11
  9. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/extract.py +3 -1
  10. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/queries/column.sql +3 -3
  11. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/queries/schema.sql +7 -2
  12. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/queries/table.sql +1 -1
  13. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/pyproject.toml +1 -1
  14. castor_extractor-0.24.38/castor_extractor/warehouse/databricks/lineage.py +0 -69
  15. castor_extractor-0.24.38/castor_extractor/warehouse/databricks/lineage_test.py +0 -89
  16. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/Dockerfile +0 -0
  17. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/DockerfileUsage.md +0 -0
  18. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/LICENCE +0 -0
  19. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/README.md +0 -0
  20. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/__init__.py +0 -0
  21. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/__init__.py +0 -0
  22. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_bigquery.py +0 -0
  23. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_confluence.py +0 -0
  24. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_databricks.py +0 -0
  25. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_domo.py +0 -0
  26. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_looker.py +0 -0
  27. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_looker_studio.py +0 -0
  28. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_metabase_api.py +0 -0
  29. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_metabase_db.py +0 -0
  30. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_mode.py +0 -0
  31. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_mysql.py +0 -0
  32. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_notion.py +0 -0
  33. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_postgres.py +0 -0
  34. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_powerbi.py +0 -0
  35. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_qlik.py +0 -0
  36. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_redshift.py +0 -0
  37. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_salesforce.py +0 -0
  38. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_salesforce_reporting.py +0 -0
  39. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_sigma.py +0 -0
  40. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_snowflake.py +0 -0
  41. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_sqlserver.py +0 -0
  42. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_strategy.py +0 -0
  43. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_tableau.py +0 -0
  44. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/extract_thoughtspot.py +0 -0
  45. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/file_check.py +0 -0
  46. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/commands/upload.py +0 -0
  47. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/__init__.py +0 -0
  48. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/column.py +0 -0
  49. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/column_test.py +0 -0
  50. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/constants.py +0 -0
  51. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/enums.py +0 -0
  52. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/file.py +0 -0
  53. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/file_test.py +0 -0
  54. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/file_test_users.csv +0 -0
  55. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/file_test_users_valid.csv +0 -0
  56. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/templates/__init__.py +0 -0
  57. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/file_checker/templates/generic_warehouse.py +0 -0
  58. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/__init__.py +0 -0
  59. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/__init__.py +0 -0
  60. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/assets.py +0 -0
  61. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/client/__init__.py +0 -0
  62. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/client/client.py +0 -0
  63. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/client/client_test.py +0 -0
  64. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/client/credentials.py +0 -0
  65. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/client/endpoints.py +0 -0
  66. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/client/pagination.py +0 -0
  67. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/extract.py +0 -0
  68. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/utils.py +0 -0
  69. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/confluence/utils_test.py +0 -0
  70. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/__init__.py +0 -0
  71. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/assets.py +0 -0
  72. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/client/__init__.py +0 -0
  73. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/client/client.py +0 -0
  74. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/client/client_test.py +0 -0
  75. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/client/constants.py +0 -0
  76. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/client/credentials.py +0 -0
  77. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/client/endpoints.py +0 -0
  78. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/client/pagination.py +0 -0
  79. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/knowledge/notion/extract.py +0 -0
  80. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/logger.py +0 -0
  81. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/quality/__init__.py +0 -0
  82. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/quality/soda/__init__.py +0 -0
  83. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/quality/soda/assets.py +0 -0
  84. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/quality/soda/client/__init__.py +0 -0
  85. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/quality/soda/client/client.py +0 -0
  86. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/quality/soda/client/credentials.py +0 -0
  87. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/quality/soda/client/endpoints.py +0 -0
  88. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/quality/soda/client/pagination.py +0 -0
  89. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/__init__.py +0 -0
  90. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/coalesce/__init__.py +0 -0
  91. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/coalesce/assets.py +0 -0
  92. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/coalesce/client/__init__.py +0 -0
  93. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/coalesce/client/client.py +0 -0
  94. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/coalesce/client/credentials.py +0 -0
  95. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/coalesce/client/endpoint.py +0 -0
  96. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/coalesce/client/pagination.py +0 -0
  97. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/dbt/__init__.py +0 -0
  98. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/dbt/assets.py +0 -0
  99. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/dbt/client.py +0 -0
  100. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/dbt/client_test.py +0 -0
  101. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/transformation/dbt/credentials.py +0 -0
  102. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/types.py +0 -0
  103. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/__init__.py +0 -0
  104. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/constant.py +0 -0
  105. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/enums.py +0 -0
  106. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/env.py +0 -0
  107. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/env_test.py +0 -0
  108. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/settings.py +0 -0
  109. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/upload.py +0 -0
  110. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/upload_test.py +0 -0
  111. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/uploader/utils.py +0 -0
  112. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/__init__.py +0 -0
  113. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/argument_parser.py +0 -0
  114. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/argument_parser_test.py +0 -0
  115. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/batch.py +0 -0
  116. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/batch_test.py +0 -0
  117. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/__init__.py +0 -0
  118. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/abstract.py +0 -0
  119. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/__init__.py +0 -0
  120. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/auth.py +0 -0
  121. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/auth_test.py +0 -0
  122. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/client.py +0 -0
  123. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/client_test.py +0 -0
  124. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/pagination.py +0 -0
  125. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/pagination_test.py +0 -0
  126. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/safe_request.py +0 -0
  127. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/safe_request_test.py +0 -0
  128. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/utils.py +0 -0
  129. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/api/utils_test.py +0 -0
  130. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/postgres.py +0 -0
  131. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/query.py +0 -0
  132. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/uri.py +0 -0
  133. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/client/uri_test.py +0 -0
  134. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/collection.py +0 -0
  135. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/collection_test.py +0 -0
  136. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/constants.py +0 -0
  137. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/deprecate.py +0 -0
  138. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/env.py +0 -0
  139. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/files.py +0 -0
  140. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/files_test.py +0 -0
  141. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/formatter.py +0 -0
  142. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/formatter_test.csv +0 -0
  143. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/formatter_test.json +0 -0
  144. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/formatter_test.py +0 -0
  145. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/json_stream_write.py +0 -0
  146. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/load.py +0 -0
  147. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/object.py +0 -0
  148. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/object_test.py +0 -0
  149. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/pager/__init__.py +0 -0
  150. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/pager/pager.py +0 -0
  151. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/pager/pager_on_id.py +0 -0
  152. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/pager/pager_on_id_test.py +0 -0
  153. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/pager/pager_test.py +0 -0
  154. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/retry.py +0 -0
  155. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/retry_test.py +0 -0
  156. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/safe.py +0 -0
  157. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/safe_test.py +0 -0
  158. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/salesforce/__init__.py +0 -0
  159. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/salesforce/client.py +0 -0
  160. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/salesforce/client_test.py +0 -0
  161. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/salesforce/constants.py +0 -0
  162. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/salesforce/credentials.py +0 -0
  163. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/salesforce/credentials_test.py +0 -0
  164. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/salesforce/pagination.py +0 -0
  165. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/store.py +0 -0
  166. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/string.py +0 -0
  167. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/string_test.py +0 -0
  168. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/time.py +0 -0
  169. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/time_test.py +0 -0
  170. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/type.py +0 -0
  171. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/url.py +0 -0
  172. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/url_test.py +0 -0
  173. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/validation.py +0 -0
  174. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/validation_test.py +0 -0
  175. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/utils/write.py +0 -0
  176. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/__init__.py +0 -0
  177. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/__init__.py +0 -0
  178. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/assets.py +0 -0
  179. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/client/__init__.py +0 -0
  180. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/client/client.py +0 -0
  181. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/client/credentials.py +0 -0
  182. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/client/endpoints.py +0 -0
  183. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/client/pagination.py +0 -0
  184. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/client/pagination_test.py +0 -0
  185. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/domo/extract.py +0 -0
  186. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/__init__.py +0 -0
  187. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/__init__.py +0 -0
  188. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/client.py +0 -0
  189. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/client_test.py +0 -0
  190. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/constants.py +0 -0
  191. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/credentials.py +0 -0
  192. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/extraction_parameters.py +0 -0
  193. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/sdk.py +0 -0
  194. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/sdk_test.py +0 -0
  195. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/api/utils.py +0 -0
  196. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/assets.py +0 -0
  197. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/constant.py +0 -0
  198. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/constants.py +0 -0
  199. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/extract.py +0 -0
  200. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/fields.py +0 -0
  201. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/fields_test.py +0 -0
  202. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker/multithreading.py +0 -0
  203. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/__init__.py +0 -0
  204. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/assets.py +0 -0
  205. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/__init__.py +0 -0
  206. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/admin_sdk_client.py +0 -0
  207. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/client.py +0 -0
  208. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/credentials.py +0 -0
  209. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/endpoints.py +0 -0
  210. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/enums.py +0 -0
  211. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/looker_studio_api_client.py +0 -0
  212. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/pagination.py +0 -0
  213. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/client/queries/query.sql +0 -0
  214. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/extract.py +0 -0
  215. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/looker_studio/extract_test.py +0 -0
  216. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/__init__.py +0 -0
  217. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/assets.py +0 -0
  218. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/__init__.py +0 -0
  219. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/api/__init__.py +0 -0
  220. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/api/client.py +0 -0
  221. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/api/client_test.py +0 -0
  222. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/api/credentials.py +0 -0
  223. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/__init__.py +0 -0
  224. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/client.py +0 -0
  225. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/credentials.py +0 -0
  226. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/.sqlfluff +0 -0
  227. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/base_url.sql +0 -0
  228. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/card.sql +0 -0
  229. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/collection.sql +0 -0
  230. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/dashboard.sql +0 -0
  231. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/dashboard_cards.sql +0 -0
  232. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/database.sql +0 -0
  233. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/table.sql +0 -0
  234. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/db/queries/user.sql +0 -0
  235. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/decryption.py +0 -0
  236. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/decryption_test.py +0 -0
  237. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/client/shared.py +0 -0
  238. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/errors.py +0 -0
  239. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/extract.py +0 -0
  240. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/metabase/types.py +0 -0
  241. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/__init__.py +0 -0
  242. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/assets.py +0 -0
  243. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/client/__init__.py +0 -0
  244. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/client/client.py +0 -0
  245. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/client/client_test.json +0 -0
  246. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/client/client_test.py +0 -0
  247. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/client/constants.py +0 -0
  248. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/client/credentials.py +0 -0
  249. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/errors.py +0 -0
  250. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/mode/extract.py +0 -0
  251. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/__init__.py +0 -0
  252. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/assets.py +0 -0
  253. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/__init__.py +0 -0
  254. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/authentication.py +0 -0
  255. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/client_test.py +0 -0
  256. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/constants.py +0 -0
  257. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/credentials.py +0 -0
  258. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/credentials_test.py +0 -0
  259. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/endpoints.py +0 -0
  260. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/client/pagination.py +0 -0
  261. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/powerbi/extract.py +0 -0
  262. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/__init__.py +0 -0
  263. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/assets.py +0 -0
  264. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/__init__.py +0 -0
  265. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/constants.py +0 -0
  266. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/__init__.py +0 -0
  267. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/client.py +0 -0
  268. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/constants.py +0 -0
  269. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/credentials.py +0 -0
  270. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/error.py +0 -0
  271. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/error_test.py +0 -0
  272. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/json_rpc.py +0 -0
  273. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/json_rpc_test.py +0 -0
  274. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/engine/websocket.py +0 -0
  275. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/master.py +0 -0
  276. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/rest.py +0 -0
  277. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/client/rest_test.py +0 -0
  278. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/qlik/extract.py +0 -0
  279. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/salesforce_reporting/__init__.py +0 -0
  280. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/salesforce_reporting/assets.py +0 -0
  281. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/salesforce_reporting/client/__init__.py +0 -0
  282. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/salesforce_reporting/client/rest.py +0 -0
  283. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/salesforce_reporting/client/soql.py +0 -0
  284. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/salesforce_reporting/extract.py +0 -0
  285. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/__init__.py +0 -0
  286. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/assets.py +0 -0
  287. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/client/__init__.py +0 -0
  288. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/client/client.py +0 -0
  289. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/client/client_test.py +0 -0
  290. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/client/credentials.py +0 -0
  291. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/client/endpoints.py +0 -0
  292. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/client/pagination.py +0 -0
  293. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/client/sources_transformer.py +0 -0
  294. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/client/sources_transformer_test.py +0 -0
  295. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/sigma/extract.py +0 -0
  296. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/strategy/__init__.py +0 -0
  297. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/strategy/assets.py +0 -0
  298. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/strategy/client/__init__.py +0 -0
  299. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/strategy/client/client.py +0 -0
  300. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/strategy/client/credentials.py +0 -0
  301. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/strategy/client/properties.py +0 -0
  302. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/strategy/extract.py +0 -0
  303. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/__init__.py +0 -0
  304. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/assets.py +0 -0
  305. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/__init__.py +0 -0
  306. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/client.py +0 -0
  307. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/client_metadata_api.py +0 -0
  308. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/client_metadata_api_test.py +0 -0
  309. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/client_rest_api.py +0 -0
  310. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/client_tsc.py +0 -0
  311. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/credentials.py +0 -0
  312. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/errors.py +0 -0
  313. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/gql_queries.py +0 -0
  314. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/client/rest_fields.py +0 -0
  315. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/constants.py +0 -0
  316. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/tableau/extract.py +0 -0
  317. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/thoughtspot/__init__.py +0 -0
  318. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/thoughtspot/assets.py +0 -0
  319. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/thoughtspot/client/__init__.py +0 -0
  320. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/thoughtspot/client/client.py +0 -0
  321. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/thoughtspot/client/credentials.py +0 -0
  322. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/thoughtspot/client/endpoints.py +0 -0
  323. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/thoughtspot/client/pagination.py +0 -0
  324. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/visualization/thoughtspot/extract.py +0 -0
  325. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/__init__.py +0 -0
  326. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/abstract/__init__.py +0 -0
  327. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/abstract/asset.py +0 -0
  328. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/abstract/asset_test.py +0 -0
  329. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/abstract/extract.py +0 -0
  330. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/abstract/query.py +0 -0
  331. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/abstract/time_filter.py +0 -0
  332. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/abstract/time_filter_test.py +0 -0
  333. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/__init__.py +0 -0
  334. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/client.py +0 -0
  335. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/client_test.py +0 -0
  336. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/credentials.py +0 -0
  337. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/extract.py +0 -0
  338. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/.sqlfluff +0 -0
  339. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/column.sql +0 -0
  340. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/cte/sharded.sql +0 -0
  341. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/database.sql +0 -0
  342. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/query.sql +0 -0
  343. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/schema.sql +0 -0
  344. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/table.sql +0 -0
  345. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/table_with_tags.sql +0 -0
  346. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/user.sql +0 -0
  347. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/queries/view_ddl.sql +0 -0
  348. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/query.py +0 -0
  349. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/bigquery/types.py +0 -0
  350. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/__init__.py +0 -0
  351. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/api_client.py +0 -0
  352. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/api_client_test.py +0 -0
  353. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/credentials.py +0 -0
  354. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/endpoints.py +0 -0
  355. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/enums.py +0 -0
  356. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/extract.py +0 -0
  357. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/format.py +0 -0
  358. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/format_test.py +0 -0
  359. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/pagination.py +0 -0
  360. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/types.py +0 -0
  361. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/utils.py +0 -0
  362. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/databricks/utils_test.py +0 -0
  363. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/__init__.py +0 -0
  364. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/client.py +0 -0
  365. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/client_test.py +0 -0
  366. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/extract.py +0 -0
  367. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/queries/.sqlfluff +0 -0
  368. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/queries/column.sql +0 -0
  369. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/queries/database.sql +0 -0
  370. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/queries/query.sql +0 -0
  371. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/queries/schema.sql +0 -0
  372. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/queries/table.sql +0 -0
  373. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/queries/user.sql +0 -0
  374. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/queries/view_ddl.sql +0 -0
  375. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/mysql/query.py +0 -0
  376. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/__init__.py +0 -0
  377. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/extract.py +0 -0
  378. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/queries/.sqlfluff +0 -0
  379. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/queries/column.sql +0 -0
  380. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/queries/database.sql +0 -0
  381. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/queries/group.sql +0 -0
  382. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/queries/schema.sql +0 -0
  383. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/queries/table.sql +0 -0
  384. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/queries/user.sql +0 -0
  385. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/postgres/query.py +0 -0
  386. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/__init__.py +0 -0
  387. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/client.py +0 -0
  388. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/client_test.py +0 -0
  389. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/extract.py +0 -0
  390. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/extract_test.py +0 -0
  391. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/.sqlfluff +0 -0
  392. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/column.sql +0 -0
  393. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/database.sql +0 -0
  394. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/group.sql +0 -0
  395. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/query.sql +0 -0
  396. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/query_serverless.sql +0 -0
  397. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/schema.sql +0 -0
  398. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/table.sql +0 -0
  399. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/table_freshness.sql +0 -0
  400. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/user.sql +0 -0
  401. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/queries/view_ddl.sql +0 -0
  402. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/redshift/query.py +0 -0
  403. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/salesforce/__init__.py +0 -0
  404. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/salesforce/client.py +0 -0
  405. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/salesforce/constants.py +0 -0
  406. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/salesforce/extract.py +0 -0
  407. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/salesforce/format.py +0 -0
  408. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/salesforce/format_test.py +0 -0
  409. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/salesforce/pagination.py +0 -0
  410. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/salesforce/soql.py +0 -0
  411. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/__init__.py +0 -0
  412. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/client.py +0 -0
  413. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/client_test.py +0 -0
  414. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/credentials.py +0 -0
  415. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/credentials_test.py +0 -0
  416. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/extract.py +0 -0
  417. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/.sqlfluff +0 -0
  418. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/column.sql +0 -0
  419. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/column_lineage.sql +0 -0
  420. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/database.sql +0 -0
  421. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/function.sql +0 -0
  422. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/grant_to_role.sql +0 -0
  423. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/grant_to_user.sql +0 -0
  424. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/query.sql +0 -0
  425. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/role.sql +0 -0
  426. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/schema.sql +0 -0
  427. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/table.sql +0 -0
  428. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/user.sql +0 -0
  429. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/queries/view_ddl.sql +0 -0
  430. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/snowflake/query.py +0 -0
  431. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/__init__.py +0 -0
  432. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/client.py +0 -0
  433. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/queries/.sqlfluff +0 -0
  434. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/queries/database.sql +0 -0
  435. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/queries/user.sql +0 -0
  436. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/sqlserver/query.py +0 -0
  437. {castor_extractor-0.24.38 → castor_extractor-0.24.40}/castor_extractor/warehouse/synapse/queries/column.sql +0 -0
@@ -1,5 +1,15 @@
1
1
  # Changelog
2
2
 
3
+ ## 0.24.40 - 2025-08-18
4
+
5
+ * SQLServer: fix database allowlist/blocklist filtering
6
+
7
+ ## 0.24.39 - 2025-08-18
8
+
9
+ * Databricks:
10
+ * Fix vanishing owner ID column for tables
11
+ * Deduplicate lineage with SQL to reduce memory use
12
+
3
13
  ## 0.24.38 - 2025-08-07
4
14
 
5
15
  * Uploader: Support US and EU zones
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: castor-extractor
3
- Version: 0.24.38
3
+ Version: 0.24.40
4
4
  Summary: Extract your metadata assets.
5
5
  Home-page: https://www.castordoc.com/
6
6
  License: EULA
@@ -215,6 +215,16 @@ For any questions or bug report, contact us at [support@coalesce.io](mailto:supp
215
215
 
216
216
  # Changelog
217
217
 
218
+ ## 0.24.40 - 2025-08-18
219
+
220
+ * SQLServer: fix database allowlist/blocklist filtering
221
+
222
+ ## 0.24.39 - 2025-08-18
223
+
224
+ * Databricks:
225
+ * Fix vanishing owner ID column for tables
226
+ * Deduplicate lineage with SQL to reduce memory use
227
+
218
228
  ## 0.24.38 - 2025-08-07
219
229
 
220
230
  * Uploader: Support US and EU zones
@@ -28,6 +28,7 @@ POWERBI_DEFAULT_TIMEOUT_S = 30
28
28
  METADATA_BATCH_SIZE = 100
29
29
  POWERBI_SCAN_STATUS_DONE = "Succeeded"
30
30
  POWERBI_SCAN_SLEEP_S = 1
31
+ POWERBI_SCAN_TIMEOUT_S = 60
31
32
 
32
33
  MAX_RETRY_PAGES = 1
33
34
  RETRY_PAGES_TIMEOUT_MS = 35 * 1000 # 35 seconds
@@ -142,7 +143,7 @@ class PowerbiClient(APIClient):
142
143
  endpoint = self.endpoint_factory.metadata_scan_status(scan_id)
143
144
  total_waiting_time_s = 0
144
145
 
145
- while total_waiting_time_s < POWERBI_DEFAULT_TIMEOUT_S:
146
+ while total_waiting_time_s < POWERBI_SCAN_TIMEOUT_S:
146
147
  try:
147
148
  result = self._get(endpoint)
148
149
  except HTTPError as e:
@@ -46,12 +46,11 @@ class DatabricksClient:
46
46
 
47
47
  @staticmethod
48
48
  def _match_table_with_user(table: dict, user_mapping: dict) -> dict:
49
+ """Matches the table's owner email to an ID, or None if not found."""
49
50
  table_owner_email = table.get("owner_email")
50
- if not table_owner_email:
51
- return table
52
- owner_external_id = user_mapping.get(table_owner_email)
53
- if not owner_external_id:
54
- return table
51
+ owner_external_id = (
52
+ user_mapping.get(table_owner_email) if table_owner_email else None
53
+ )
55
54
  return {**table, "owner_external_id": owner_external_id}
56
55
 
57
56
  @staticmethod
@@ -36,5 +36,6 @@ def test_DatabricksClient__match_table_with_user():
36
36
  assert table_with_owner == {**table, "owner_external_id": 3}
37
37
 
38
38
  table_without_owner = {"id": 1, "owner_email": None}
39
+ expected = {"id": 1, "owner_email": None, "owner_external_id": None}
39
40
  actual = client._match_table_with_user(table_without_owner, user_mapping)
40
- assert actual == table_without_owner
41
+ assert actual == expected
@@ -0,0 +1,25 @@
1
+ /*
2
+ Selects all column lineage events for the given day.
3
+ This excludes self-lineage and deduplicates (parent, child) pairs to keep only the most recent lineage event.
4
+
5
+ Passing parameters is not always supported, so the query must be Python-formatted to set the date.
6
+ */
7
+ WITH deduplicated_lineage AS (
8
+ SELECT *,
9
+ ROW_NUMBER() OVER (
10
+ PARTITION BY source_table_full_name, source_column_name, target_table_full_name, target_column_name
11
+ ORDER BY event_time DESC
12
+ ) AS rank
13
+ FROM system.access.column_lineage
14
+ WHERE
15
+ TRUE
16
+ AND event_date = DATE('{day}')
17
+ AND source_table_full_name IS NOT NULL
18
+ AND source_column_name IS NOT NULL
19
+ AND target_table_full_name IS NOT NULL
20
+ AND target_column_name IS NOT NULL
21
+ AND CONCAT(source_table_full_name, '.', source_column_name) != CONCAT(target_table_full_name, '.', target_column_name)
22
+ )
23
+ SELECT *
24
+ FROM deduplicated_lineage
25
+ WHERE rank = 1
@@ -0,0 +1,23 @@
1
+ /*
2
+ Selects all table lineage events for the given day.
3
+ This excludes self-lineage and deduplicates (parent, child) pairs to keep only the most recent lineage event.
4
+
5
+ Passing parameters is not always supported, so the query must be Python-formatted to set the date.
6
+ */
7
+ WITH deduplicated_lineage AS (
8
+ SELECT *,
9
+ ROW_NUMBER() OVER (
10
+ PARTITION BY source_table_full_name, target_table_full_name
11
+ ORDER BY event_time DESC
12
+ ) AS rank
13
+ FROM system.access.table_lineage
14
+ WHERE
15
+ TRUE
16
+ AND event_date = DATE('{day}')
17
+ AND source_table_full_name IS NOT NULL
18
+ AND target_table_full_name IS NOT NULL
19
+ AND source_table_full_name != target_table_full_name
20
+ )
21
+ SELECT *
22
+ FROM deduplicated_lineage
23
+ WHERE rank = 1
@@ -4,20 +4,25 @@ from datetime import date
4
4
 
5
5
  from databricks import sql # type: ignore
6
6
 
7
+ from ...utils import load_file
7
8
  from .credentials import DatabricksCredentials
8
9
  from .enums import LineageEntity, TagEntity
9
10
  from .format import TagMapping
10
- from .lineage import valid_lineage
11
11
  from .utils import build_path, tag_label
12
12
 
13
13
  logger = logging.getLogger(__name__)
14
14
 
15
15
  _INFORMATION_SCHEMA_SQL = "SELECT * FROM system.information_schema"
16
16
 
17
- _LINEAGE_SQL_TPL = """
18
- SELECT * FROM system.access.{table_name}
19
- WHERE event_date = DATE('{day}')
20
- """
17
+ _LINEAGE_SQL_PATHS = {
18
+ LineageEntity.COLUMN: "queries/column_lineage.sql",
19
+ LineageEntity.TABLE: "queries/table_lineage.sql",
20
+ }
21
+
22
+
23
+ def _load_lineage_query(lineage_entity: LineageEntity) -> str:
24
+ filename = _LINEAGE_SQL_PATHS[lineage_entity]
25
+ return load_file(filename, __file__)
21
26
 
22
27
 
23
28
  class DatabricksSQLClient:
@@ -95,13 +100,11 @@ class DatabricksSQLClient:
95
100
  Unfortunately, passing parameters is not always supported. We have to
96
101
  format the query beforehand and pass it as plain text for execution.
97
102
  """
98
- table_name = f"{lineage_entity.value.lower()}_lineage"
99
- query = _LINEAGE_SQL_TPL.format(
100
- table_name=table_name,
101
- day=day,
102
- )
103
+ query_template = _load_lineage_query(lineage_entity)
104
+ query = query_template.format(day=day)
105
+
103
106
  result = self.execute_sql(query)
104
107
  data = []
105
108
  for row in result:
106
109
  data.append(row.asDict())
107
- return valid_lineage(data, lineage_entity)
110
+ return data
@@ -52,7 +52,9 @@ def extract_all(**kwargs) -> None:
52
52
  client = MSSQLClient(credentials=_credentials(kwargs))
53
53
 
54
54
  databases = filter_items(
55
- client.get_databases(), kwargs.get("allowed"), kwargs.get("blocked")
55
+ items=client.get_databases(),
56
+ allowed=kwargs.get("db_allowed"),
57
+ blocked=kwargs.get("db_blocked"),
56
58
  )
57
59
 
58
60
  query_builder = MSSQLQueryBuilder(
@@ -91,9 +91,9 @@ columns AS (
91
91
  LEFT JOIN column_ids AS i
92
92
  ON
93
93
  (
94
- c.table_name = i.table_name
95
- AND c.table_schema = i.schema_name
96
- AND c.column_name = i.column_name
94
+ c.table_name COLLATE DATABASE_DEFAULT = i.table_name COLLATE DATABASE_DEFAULT
95
+ AND c.table_schema COLLATE DATABASE_DEFAULT = i.schema_name COLLATE DATABASE_DEFAULT
96
+ AND c.column_name COLLATE DATABASE_DEFAULT = i.column_name COLLATE DATABASE_DEFAULT
97
97
  )
98
98
  )
99
99
 
@@ -1,4 +1,9 @@
1
- -- Fetch database information
1
+ /*
2
+ Fetch database information
3
+
4
+ Collation is a set of rules that defines how text data is stored and compared, and it can differ between databases.
5
+ The "COLLATE DATABASE_DEFAULT" is to ensure that text is compared with the same collation.
6
+ */
2
7
  WITH ids AS (
3
8
  SELECT DISTINCT
4
9
  table_catalog,
@@ -19,4 +24,4 @@ INNER JOIN ids AS i
19
24
  LEFT JOIN {database}.sys.sysusers AS u
20
25
  ON s.principal_id = u.uid
21
26
  LEFT JOIN {database}.sys.databases AS d
22
- ON i.table_catalog = d.name
27
+ ON i.table_catalog COLLATE DATABASE_DEFAULT = d.name COLLATE DATABASE_DEFAULT
@@ -92,7 +92,7 @@ meta AS (
92
92
  FROM
93
93
  {database}.information_schema.tables AS t
94
94
  LEFT JOIN {database}.sys.databases AS db
95
- ON t.table_catalog = db.name
95
+ ON t.table_catalog COLLATE DATABASE_DEFAULT = db.name COLLATE DATABASE_DEFAULT
96
96
  )
97
97
 
98
98
  SELECT
@@ -3,7 +3,7 @@ requires = ["setuptools>=61.2"]
3
3
 
4
4
  [tool.poetry]
5
5
  name = "castor-extractor"
6
- version = "0.24.38"
6
+ version = "0.24.40"
7
7
  description = "Extract your metadata assets."
8
8
  authors = ["Castor <support@castordoc.com>"]
9
9
  license = "EULA"
@@ -1,69 +0,0 @@
1
- from typing import Iterable, Optional
2
-
3
- from .enums import LineageEntity
4
-
5
-
6
- class LineageProcessor:
7
- """
8
- helper class that handles lineage deduplication and filtering
9
- """
10
-
11
- def __init__(self, lineage_entity: LineageEntity):
12
- self.lineage_entity = lineage_entity
13
-
14
- self.lineage: dict[tuple[str, str], dict] = dict()
15
-
16
- def _parent_path(self, link) -> Optional[str]:
17
- if self.lineage_entity == LineageEntity.TABLE:
18
- return link["source_table_full_name"]
19
-
20
- source_table = link["source_table_full_name"]
21
- source_column = link["source_column_name"]
22
- if not (source_table and source_column):
23
- return None
24
-
25
- return f"{source_table}.{source_column}"
26
-
27
- def _child_path(self, link) -> Optional[str]:
28
- if self.lineage_entity == LineageEntity.TABLE:
29
- return link["target_table_full_name"]
30
-
31
- target_table = link["target_table_full_name"]
32
- target_column = link["target_column_name"]
33
- if not (target_table and target_column):
34
- return None
35
-
36
- return f"{target_table}.{target_column}"
37
-
38
- def add(self, link: dict) -> None:
39
- """
40
- If the parent and child paths are valid, keeps the most recent lineage
41
- link in the `self.lineage` map.
42
- """
43
- parent = self._parent_path(link)
44
- child = self._child_path(link)
45
- timestamp = link["event_time"]
46
-
47
- if not (parent and child and parent != child):
48
- return
49
-
50
- key = (parent, child)
51
- if key in self.lineage and self.lineage[key]["event_time"] > timestamp:
52
- return
53
-
54
- self.lineage[key] = link
55
-
56
-
57
- def valid_lineage(
58
- lineage: Iterable[dict], lineage_entity: LineageEntity
59
- ) -> list[dict]:
60
- """
61
- Filters out self-lineage or lineage with a missing source or target path,
62
- then deduplicates by picking the link with the most recent event timestmap.
63
- """
64
- deduplicated_lineage = LineageProcessor(lineage_entity)
65
-
66
- for link in lineage:
67
- deduplicated_lineage.add(link)
68
-
69
- return list(deduplicated_lineage.lineage.values())
@@ -1,89 +0,0 @@
1
- from .enums import LineageEntity
2
- from .lineage import LineageProcessor, valid_lineage
3
-
4
- _OLDER_DATE = "2025-01-01 00:00:01.0"
5
- _CLOSER_DATE = "2025-01-01 02:02:02.0"
6
-
7
- _TABLE_LINEAGES = [
8
- {
9
- "source_table_full_name": "a.b.source",
10
- "target_table_full_name": "a.b.target",
11
- "event_time": _CLOSER_DATE,
12
- "other": "more recent stuff",
13
- },
14
- {
15
- "source_table_full_name": "a.b.source",
16
- "target_table_full_name": "a.b.target",
17
- "event_time": _OLDER_DATE,
18
- "other": "stuff that's too old",
19
- },
20
- {
21
- "source_table_full_name": "no target",
22
- "target_table_full_name": None,
23
- "event_time": _CLOSER_DATE,
24
- },
25
- {
26
- "source_table_full_name": None,
27
- "target_table_full_name": "no source",
28
- "event_time": _CLOSER_DATE,
29
- },
30
- ]
31
-
32
-
33
- _COLUMN_LINEAGES = [
34
- {
35
- "source_table_full_name": "a.b.source",
36
- "source_column_name": "src_col",
37
- "target_table_full_name": "a.b.target",
38
- "target_column_name": "trgt_col",
39
- "event_time": _OLDER_DATE,
40
- "other": "old stuff",
41
- },
42
- {
43
- "source_table_full_name": "a.b.source",
44
- "source_column_name": "src_col",
45
- "target_table_full_name": "a.b.target",
46
- "target_column_name": "trgt_col",
47
- "event_time": _CLOSER_DATE,
48
- "other": "newer stuff",
49
- },
50
- {
51
- "source_table_full_name": "a.b.toto",
52
- "source_column_name": "toto_col",
53
- "target_table_full_name": "a.b.tata",
54
- "target_column_name": "tata_col",
55
- "event_time": _OLDER_DATE,
56
- },
57
- {
58
- "source_table_full_name": "a.b.source",
59
- "source_column_name": "a.b.source",
60
- "target_table_full_name": None,
61
- "target_column_name": None,
62
- "event_time": _CLOSER_DATE,
63
- },
64
- ]
65
-
66
-
67
- def test_valid_lineage():
68
- table_links = valid_lineage(_TABLE_LINEAGES, LineageEntity.TABLE)
69
-
70
- assert len(table_links) == 1
71
- assert table_links[0]["source_table_full_name"] == "a.b.source"
72
- assert table_links[0]["target_table_full_name"] == "a.b.target"
73
- assert table_links[0]["event_time"] == _CLOSER_DATE
74
- assert table_links[0]["other"] == "more recent stuff"
75
-
76
-
77
- def test_LineageLinks_add():
78
- deduplicated_lineage = LineageProcessor(LineageEntity.COLUMN)
79
- for link in _COLUMN_LINEAGES:
80
- deduplicated_lineage.add(link)
81
-
82
- lineage = deduplicated_lineage.lineage
83
- assert len(lineage) == 2
84
- assert ("a.b.source.src_col", "a.b.target.trgt_col") in lineage
85
- assert ("a.b.toto.toto_col", "a.b.tata.tata_col") in lineage
86
- assert (
87
- lineage[("a.b.source.src_col", "a.b.target.trgt_col")]["other"]
88
- == "newer stuff"
89
- )