airbyte-cdk 6.34.0.dev0__tar.gz → 6.34.0.dev1__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.
Files changed (369) hide show
  1. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/PKG-INFO +1 -1
  2. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/connector_builder/connector_builder_handler.py +16 -12
  3. airbyte_cdk-6.34.0.dev1/airbyte_cdk/connector_builder/test_reader/__init__.py +7 -0
  4. airbyte_cdk-6.34.0.dev1/airbyte_cdk/connector_builder/test_reader/helpers.py +591 -0
  5. airbyte_cdk-6.34.0.dev1/airbyte_cdk/connector_builder/test_reader/message_grouper.py +160 -0
  6. airbyte_cdk-6.34.0.dev1/airbyte_cdk/connector_builder/test_reader/reader.py +441 -0
  7. airbyte_cdk-6.34.0.dev1/airbyte_cdk/connector_builder/test_reader/types.py +75 -0
  8. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/entrypoint.py +6 -6
  9. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/logger.py +1 -4
  10. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/incremental/concurrent_partition_cursor.py +56 -25
  11. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/incremental/datetime_based_cursor.py +5 -0
  12. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/default_paginator.py +10 -0
  13. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/abstract_file_based_spec.py +2 -1
  14. airbyte_cdk-6.34.0.dev1/airbyte_cdk/sources/file_based/config/validate_config_transfer_modes.py +81 -0
  15. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_based_source.py +70 -37
  16. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_based_stream_reader.py +107 -12
  17. airbyte_cdk-6.34.0.dev1/airbyte_cdk/sources/file_based/stream/__init__.py +13 -0
  18. airbyte_cdk-6.34.0.dev1/airbyte_cdk/sources/file_based/stream/identities_stream.py +47 -0
  19. airbyte_cdk-6.34.0.dev1/airbyte_cdk/sources/file_based/stream/permissions_file_based_stream.py +85 -0
  20. airbyte_cdk-6.34.0.dev1/airbyte_cdk/sources/specs/transfer_modes.py +26 -0
  21. airbyte_cdk-6.34.0.dev1/airbyte_cdk/sources/streams/permissions/identities_stream.py +75 -0
  22. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/mapping_helpers.py +43 -2
  23. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/print_buffer.py +0 -4
  24. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/pyproject.toml +1 -1
  25. airbyte_cdk-6.34.0.dev0/airbyte_cdk/connector_builder/message_grouper.py +0 -448
  26. airbyte_cdk-6.34.0.dev0/airbyte_cdk/sources/file_based/stream/__init__.py +0 -4
  27. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/LICENSE.txt +0 -0
  28. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/LICENSE_SHORT +0 -0
  29. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/README.md +0 -0
  30. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/__init__.py +0 -0
  31. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/cli/__init__.py +0 -0
  32. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/cli/source_declarative_manifest/__init__.py +0 -0
  33. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/cli/source_declarative_manifest/_run.py +0 -0
  34. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/cli/source_declarative_manifest/spec.json +0 -0
  35. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/config_observation.py +0 -0
  36. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/connector.py +0 -0
  37. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/connector_builder/README.md +0 -0
  38. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/connector_builder/__init__.py +0 -0
  39. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/connector_builder/main.py +0 -0
  40. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/connector_builder/models.py +0 -0
  41. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/__init__.py +0 -0
  42. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/destination.py +0 -0
  43. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/README.md +0 -0
  44. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/__init__.py +0 -0
  45. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/config.py +0 -0
  46. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/document_processor.py +0 -0
  47. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/embedder.py +0 -0
  48. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/indexer.py +0 -0
  49. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/test_utils.py +0 -0
  50. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/utils.py +0 -0
  51. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/destinations/vector_db_based/writer.py +0 -0
  52. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/exception_handler.py +0 -0
  53. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/models/__init__.py +0 -0
  54. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/models/airbyte_protocol.py +0 -0
  55. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/models/airbyte_protocol_serializers.py +0 -0
  56. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/models/file_transfer_record_message.py +0 -0
  57. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/models/well_known_types.py +0 -0
  58. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/py.typed +0 -0
  59. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/__init__.py +0 -0
  60. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/abstract_source.py +0 -0
  61. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/concurrent_source/__init__.py +0 -0
  62. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/concurrent_source/concurrent_read_processor.py +0 -0
  63. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/concurrent_source/concurrent_source.py +0 -0
  64. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/concurrent_source/concurrent_source_adapter.py +0 -0
  65. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/concurrent_source/partition_generation_completed_sentinel.py +0 -0
  66. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/concurrent_source/stream_thread_exception.py +0 -0
  67. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/concurrent_source/thread_pool_manager.py +0 -0
  68. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/config.py +0 -0
  69. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/connector_state_manager.py +0 -0
  70. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/__init__.py +0 -0
  71. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/async_job/__init__.py +0 -0
  72. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/async_job/job.py +0 -0
  73. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/async_job/job_orchestrator.py +0 -0
  74. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/async_job/job_tracker.py +0 -0
  75. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/async_job/repository.py +0 -0
  76. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/async_job/status.py +0 -0
  77. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/async_job/timer.py +0 -0
  78. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/auth/__init__.py +0 -0
  79. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/auth/declarative_authenticator.py +0 -0
  80. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/auth/jwt.py +0 -0
  81. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/auth/oauth.py +0 -0
  82. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/auth/selective_authenticator.py +0 -0
  83. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/auth/token.py +0 -0
  84. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/auth/token_provider.py +0 -0
  85. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/checks/__init__.py +0 -0
  86. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/checks/check_dynamic_stream.py +0 -0
  87. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/checks/check_stream.py +0 -0
  88. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/checks/connection_checker.py +0 -0
  89. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/concurrency_level/__init__.py +0 -0
  90. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/concurrency_level/concurrency_level.py +0 -0
  91. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/concurrent_declarative_source.py +0 -0
  92. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/datetime/__init__.py +0 -0
  93. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/datetime/datetime_parser.py +0 -0
  94. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/datetime/min_max_datetime.py +0 -0
  95. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/declarative_component_schema.yaml +0 -0
  96. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/declarative_source.py +0 -0
  97. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/declarative_stream.py +0 -0
  98. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/decoders/__init__.py +0 -0
  99. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/decoders/composite_raw_decoder.py +0 -0
  100. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/decoders/decoder.py +0 -0
  101. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/decoders/json_decoder.py +0 -0
  102. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/decoders/noop_decoder.py +0 -0
  103. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/decoders/pagination_decoder_decorator.py +0 -0
  104. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/decoders/xml_decoder.py +0 -0
  105. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/decoders/zipfile_decoder.py +0 -0
  106. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/exceptions.py +0 -0
  107. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/extractors/__init__.py +0 -0
  108. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/extractors/dpath_extractor.py +0 -0
  109. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/extractors/http_selector.py +0 -0
  110. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/extractors/record_extractor.py +0 -0
  111. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/extractors/record_filter.py +0 -0
  112. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/extractors/record_selector.py +0 -0
  113. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/extractors/response_to_file_extractor.py +0 -0
  114. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/extractors/type_transformer.py +0 -0
  115. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/incremental/__init__.py +0 -0
  116. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/incremental/declarative_cursor.py +0 -0
  117. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/incremental/global_substream_cursor.py +0 -0
  118. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/incremental/per_partition_cursor.py +0 -0
  119. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/incremental/per_partition_with_global.py +0 -0
  120. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/incremental/resumable_full_refresh_cursor.py +0 -0
  121. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/__init__.py +0 -0
  122. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/filters.py +0 -0
  123. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/interpolated_boolean.py +0 -0
  124. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/interpolated_mapping.py +0 -0
  125. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/interpolated_nested_mapping.py +0 -0
  126. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/interpolated_string.py +0 -0
  127. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/interpolation.py +0 -0
  128. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/jinja.py +0 -0
  129. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/interpolation/macros.py +0 -0
  130. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/manifest_declarative_source.py +0 -0
  131. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/migrations/__init__.py +0 -0
  132. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/migrations/legacy_to_per_partition_state_migration.py +0 -0
  133. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/migrations/state_migration.py +0 -0
  134. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/models/__init__.py +0 -0
  135. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/models/declarative_component_schema.py +0 -0
  136. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/parsers/__init__.py +0 -0
  137. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/parsers/custom_code_compiler.py +0 -0
  138. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/parsers/custom_exceptions.py +0 -0
  139. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/parsers/manifest_component_transformer.py +0 -0
  140. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/parsers/manifest_reference_resolver.py +0 -0
  141. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/parsers/model_to_component_factory.py +0 -0
  142. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/partition_routers/__init__.py +0 -0
  143. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/partition_routers/async_job_partition_router.py +0 -0
  144. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/partition_routers/cartesian_product_stream_slicer.py +0 -0
  145. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/partition_routers/list_partition_router.py +0 -0
  146. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/partition_routers/partition_router.py +0 -0
  147. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/partition_routers/single_partition_router.py +0 -0
  148. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/partition_routers/substream_partition_router.py +0 -0
  149. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/README.md +0 -0
  150. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/__init__.py +0 -0
  151. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/__init__.py +0 -0
  152. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/backoff_strategies/__init__.py +0 -0
  153. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/backoff_strategies/constant_backoff_strategy.py +0 -0
  154. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/backoff_strategies/exponential_backoff_strategy.py +0 -0
  155. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/backoff_strategies/header_helper.py +0 -0
  156. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/backoff_strategies/wait_time_from_header_backoff_strategy.py +0 -0
  157. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/backoff_strategies/wait_until_time_from_header_backoff_strategy.py +0 -0
  158. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/backoff_strategy.py +0 -0
  159. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/composite_error_handler.py +0 -0
  160. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/default_error_handler.py +0 -0
  161. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/default_http_response_filter.py +0 -0
  162. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/error_handler.py +0 -0
  163. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/error_handlers/http_response_filter.py +0 -0
  164. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/http_job_repository.py +0 -0
  165. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/http_requester.py +0 -0
  166. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/__init__.py +0 -0
  167. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/no_pagination.py +0 -0
  168. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/paginator.py +0 -0
  169. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/strategies/__init__.py +0 -0
  170. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/strategies/cursor_pagination_strategy.py +0 -0
  171. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/strategies/offset_increment.py +0 -0
  172. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/strategies/page_increment.py +0 -0
  173. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/strategies/pagination_strategy.py +0 -0
  174. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/paginators/strategies/stop_condition.py +0 -0
  175. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_option.py +0 -0
  176. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_options/__init__.py +0 -0
  177. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_options/datetime_based_request_options_provider.py +0 -0
  178. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_options/default_request_options_provider.py +0 -0
  179. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_options/interpolated_nested_request_input_provider.py +0 -0
  180. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_options/interpolated_request_input_provider.py +0 -0
  181. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_options/interpolated_request_options_provider.py +0 -0
  182. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_options/request_options_provider.py +0 -0
  183. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/request_path.py +0 -0
  184. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/requesters/requester.py +0 -0
  185. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/resolvers/__init__.py +0 -0
  186. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/resolvers/components_resolver.py +0 -0
  187. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/resolvers/config_components_resolver.py +0 -0
  188. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/resolvers/http_components_resolver.py +0 -0
  189. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/retrievers/__init__.py +0 -0
  190. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/retrievers/async_retriever.py +0 -0
  191. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/retrievers/retriever.py +0 -0
  192. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/retrievers/simple_retriever.py +0 -0
  193. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/schema/__init__.py +0 -0
  194. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/schema/default_schema_loader.py +0 -0
  195. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/schema/dynamic_schema_loader.py +0 -0
  196. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/schema/inline_schema_loader.py +0 -0
  197. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/schema/json_file_schema_loader.py +0 -0
  198. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/schema/schema_loader.py +0 -0
  199. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/spec/__init__.py +0 -0
  200. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/spec/spec.py +0 -0
  201. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/stream_slicers/__init__.py +0 -0
  202. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/stream_slicers/declarative_partition_generator.py +0 -0
  203. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/stream_slicers/stream_slicer.py +0 -0
  204. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/__init__.py +0 -0
  205. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/add_fields.py +0 -0
  206. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/dpath_flatten_fields.py +0 -0
  207. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/flatten_fields.py +0 -0
  208. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/keys_replace_transformation.py +0 -0
  209. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/keys_to_lower_transformation.py +0 -0
  210. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/keys_to_snake_transformation.py +0 -0
  211. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/remove_fields.py +0 -0
  212. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/transformations/transformation.py +0 -0
  213. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/types.py +0 -0
  214. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/declarative/yaml_declarative_source.py +0 -0
  215. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/embedded/__init__.py +0 -0
  216. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/embedded/base_integration.py +0 -0
  217. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/embedded/catalog.py +0 -0
  218. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/embedded/runner.py +0 -0
  219. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/embedded/tools.py +0 -0
  220. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/README.md +0 -0
  221. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/__init__.py +0 -0
  222. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/availability_strategy/__init__.py +0 -0
  223. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/availability_strategy/abstract_file_based_availability_strategy.py +0 -0
  224. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/availability_strategy/default_file_based_availability_strategy.py +0 -0
  225. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/__init__.py +0 -0
  226. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/avro_format.py +0 -0
  227. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/csv_format.py +0 -0
  228. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/excel_format.py +0 -0
  229. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/file_based_stream_config.py +0 -0
  230. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/jsonl_format.py +0 -0
  231. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/parquet_format.py +0 -0
  232. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/config/unstructured_format.py +0 -0
  233. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/discovery_policy/__init__.py +0 -0
  234. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/discovery_policy/abstract_discovery_policy.py +0 -0
  235. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/discovery_policy/default_discovery_policy.py +0 -0
  236. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/exceptions.py +0 -0
  237. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/__init__.py +0 -0
  238. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/avro_parser.py +0 -0
  239. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/csv_parser.py +0 -0
  240. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/excel_parser.py +0 -0
  241. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/file_transfer.py +0 -0
  242. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/file_type_parser.py +0 -0
  243. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/jsonl_parser.py +0 -0
  244. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/parquet_parser.py +0 -0
  245. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/file_types/unstructured_parser.py +0 -0
  246. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/remote_file.py +0 -0
  247. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/schema_helpers.py +0 -0
  248. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/schema_validation_policies/__init__.py +0 -0
  249. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/schema_validation_policies/abstract_schema_validation_policy.py +0 -0
  250. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/schema_validation_policies/default_schema_validation_policies.py +0 -0
  251. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/abstract_file_based_stream.py +0 -0
  252. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/concurrent/__init__.py +0 -0
  253. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/concurrent/adapters.py +0 -0
  254. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/concurrent/cursor/__init__.py +0 -0
  255. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/concurrent/cursor/abstract_concurrent_file_based_cursor.py +0 -0
  256. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/concurrent/cursor/file_based_concurrent_cursor.py +0 -0
  257. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/concurrent/cursor/file_based_final_state_cursor.py +0 -0
  258. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/cursor/__init__.py +0 -0
  259. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/cursor/abstract_file_based_cursor.py +0 -0
  260. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/cursor/default_file_based_cursor.py +0 -0
  261. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/stream/default_file_based_stream.py +0 -0
  262. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/file_based/types.py +0 -0
  263. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/http_config.py +0 -0
  264. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/http_logger.py +0 -0
  265. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/message/__init__.py +0 -0
  266. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/message/repository.py +0 -0
  267. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/source.py +0 -0
  268. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/__init__.py +0 -0
  269. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/availability_strategy.py +0 -0
  270. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/call_rate.py +0 -0
  271. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/checkpoint/__init__.py +0 -0
  272. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/checkpoint/checkpoint_reader.py +0 -0
  273. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/checkpoint/cursor.py +0 -0
  274. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/checkpoint/per_partition_key_serializer.py +0 -0
  275. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/checkpoint/resumable_full_refresh_cursor.py +0 -0
  276. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/checkpoint/substream_resumable_full_refresh_cursor.py +0 -0
  277. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/README.md +0 -0
  278. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/__init__.py +0 -0
  279. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/abstract_stream.py +0 -0
  280. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/abstract_stream_facade.py +0 -0
  281. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/adapters.py +0 -0
  282. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/availability_strategy.py +0 -0
  283. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/clamping.py +0 -0
  284. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/cursor.py +0 -0
  285. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/cursor_types.py +0 -0
  286. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/default_stream.py +0 -0
  287. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/exceptions.py +0 -0
  288. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/helpers.py +0 -0
  289. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/partition_enqueuer.py +0 -0
  290. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/partition_reader.py +0 -0
  291. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/partitions/__init__.py +0 -0
  292. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/partitions/partition.py +0 -0
  293. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/partitions/partition_generator.py +0 -0
  294. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/partitions/stream_slicer.py +0 -0
  295. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/partitions/types.py +0 -0
  296. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/state_converters/__init__.py +0 -0
  297. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/state_converters/abstract_stream_state_converter.py +0 -0
  298. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/concurrent/state_converters/datetime_stream_state_converter.py +0 -0
  299. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/core.py +0 -0
  300. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/__init__.py +0 -0
  301. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/availability_strategy.py +0 -0
  302. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/__init__.py +0 -0
  303. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/backoff_strategy.py +0 -0
  304. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/default_backoff_strategy.py +0 -0
  305. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/default_error_mapping.py +0 -0
  306. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/error_handler.py +0 -0
  307. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/error_message_parser.py +0 -0
  308. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/http_status_error_handler.py +0 -0
  309. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/json_error_message_parser.py +0 -0
  310. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/error_handlers/response_models.py +0 -0
  311. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/exceptions.py +0 -0
  312. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/http.py +0 -0
  313. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/http_client.py +0 -0
  314. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/rate_limiting.py +0 -0
  315. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/requests_native_auth/__init__.py +0 -0
  316. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/requests_native_auth/abstract_oauth.py +0 -0
  317. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/requests_native_auth/abstract_token.py +0 -0
  318. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/requests_native_auth/oauth.py +0 -0
  319. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/http/requests_native_auth/token.py +0 -0
  320. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/streams/utils/__init__.py +0 -0
  321. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/types.py +0 -0
  322. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/utils/__init__.py +0 -0
  323. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/utils/casing.py +0 -0
  324. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/utils/record_helper.py +0 -0
  325. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/utils/schema_helpers.py +0 -0
  326. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/utils/slice_logger.py +0 -0
  327. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/utils/transform.py +0 -0
  328. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sources/utils/types.py +0 -0
  329. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/__init__.py +0 -0
  330. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/_util/__init__.py +0 -0
  331. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/_util/hashing.py +0 -0
  332. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/_util/name_normalizers.py +0 -0
  333. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/constants.py +0 -0
  334. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/exceptions.py +0 -0
  335. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/secrets.py +0 -0
  336. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/shared/__init__.py +0 -0
  337. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/shared/catalog_providers.py +0 -0
  338. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/shared/sql_processor.py +0 -0
  339. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/sql/types.py +0 -0
  340. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/__init__.py +0 -0
  341. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/catalog_builder.py +0 -0
  342. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/entrypoint_wrapper.py +0 -0
  343. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/mock_http/__init__.py +0 -0
  344. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/mock_http/matcher.py +0 -0
  345. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/mock_http/mocker.py +0 -0
  346. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/mock_http/request.py +0 -0
  347. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/mock_http/response.py +0 -0
  348. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/mock_http/response_builder.py +0 -0
  349. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/state_builder.py +0 -0
  350. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/utils/__init__.py +0 -0
  351. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/utils/data.py +0 -0
  352. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/utils/http_mocking.py +0 -0
  353. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/utils/manifest_only_fixtures.py +0 -0
  354. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/test/utils/reading.py +0 -0
  355. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/__init__.py +0 -0
  356. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/airbyte_secrets_utils.py +0 -0
  357. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/analytics_message.py +0 -0
  358. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/constants.py +0 -0
  359. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/datetime_format_inferrer.py +0 -0
  360. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/datetime_helpers.py +0 -0
  361. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/event_timing.py +0 -0
  362. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/is_cloud_environment.py +0 -0
  363. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/message_utils.py +0 -0
  364. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/oneof_option_config.py +0 -0
  365. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/schema_inferrer.py +0 -0
  366. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/slice_hasher.py +0 -0
  367. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/spec_schema_transformations.py +0 -0
  368. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/stream_status_utils.py +0 -0
  369. {airbyte_cdk-6.34.0.dev0 → airbyte_cdk-6.34.0.dev1}/airbyte_cdk/utils/traced_exception.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: airbyte-cdk
3
- Version: 6.34.0.dev0
3
+ Version: 6.34.0.dev1
4
4
  Summary: A framework for writing Airbyte Connectors.
5
5
  Home-page: https://airbyte.com
6
6
  License: MIT
@@ -2,10 +2,11 @@
2
2
  # Copyright (c) 2023 Airbyte, Inc., all rights reserved.
3
3
  #
4
4
 
5
- import dataclasses
5
+
6
+ from dataclasses import asdict, dataclass, field
6
7
  from typing import Any, List, Mapping
7
8
 
8
- from airbyte_cdk.connector_builder.message_grouper import MessageGrouper
9
+ from airbyte_cdk.connector_builder.test_reader import TestReader
9
10
  from airbyte_cdk.models import (
10
11
  AirbyteMessage,
11
12
  AirbyteRecordMessage,
@@ -32,11 +33,11 @@ MAX_SLICES_KEY = "max_slices"
32
33
  MAX_RECORDS_KEY = "max_records"
33
34
 
34
35
 
35
- @dataclasses.dataclass
36
+ @dataclass
36
37
  class TestReadLimits:
37
- max_records: int = dataclasses.field(default=DEFAULT_MAXIMUM_RECORDS)
38
- max_pages_per_slice: int = dataclasses.field(default=DEFAULT_MAXIMUM_NUMBER_OF_PAGES_PER_SLICE)
39
- max_slices: int = dataclasses.field(default=DEFAULT_MAXIMUM_NUMBER_OF_SLICES)
38
+ max_records: int = field(default=DEFAULT_MAXIMUM_RECORDS)
39
+ max_pages_per_slice: int = field(default=DEFAULT_MAXIMUM_NUMBER_OF_PAGES_PER_SLICE)
40
+ max_slices: int = field(default=DEFAULT_MAXIMUM_NUMBER_OF_SLICES)
40
41
 
41
42
 
42
43
  def get_limits(config: Mapping[str, Any]) -> TestReadLimits:
@@ -73,17 +74,20 @@ def read_stream(
73
74
  limits: TestReadLimits,
74
75
  ) -> AirbyteMessage:
75
76
  try:
76
- handler = MessageGrouper(limits.max_pages_per_slice, limits.max_slices, limits.max_records)
77
- stream_name = configured_catalog.streams[
78
- 0
79
- ].stream.name # The connector builder only supports a single stream
80
- stream_read = handler.get_message_groups(
77
+ test_read_handler = TestReader(
78
+ limits.max_pages_per_slice, limits.max_slices, limits.max_records
79
+ )
80
+ # The connector builder only supports a single stream
81
+ stream_name = configured_catalog.streams[0].stream.name
82
+
83
+ stream_read = test_read_handler.run_test_read(
81
84
  source, config, configured_catalog, state, limits.max_records
82
85
  )
86
+
83
87
  return AirbyteMessage(
84
88
  type=MessageType.RECORD,
85
89
  record=AirbyteRecordMessage(
86
- data=dataclasses.asdict(stream_read), stream=stream_name, emitted_at=_emitted_at()
90
+ data=asdict(stream_read), stream=stream_name, emitted_at=_emitted_at()
87
91
  ),
88
92
  )
89
93
  except Exception as exc:
@@ -0,0 +1,7 @@
1
+ #
2
+ # Copyright (c) 2023 Airbyte, Inc., all rights reserved.
3
+ #
4
+
5
+ from .reader import TestReader
6
+
7
+ __all__ = ("TestReader",)
@@ -0,0 +1,591 @@
1
+ #
2
+ # Copyright (c) 2023 Airbyte, Inc., all rights reserved.
3
+ #
4
+
5
+ import json
6
+ from copy import deepcopy
7
+ from json import JSONDecodeError
8
+ from typing import Any, Dict, List, Mapping, Optional
9
+
10
+ from airbyte_cdk.connector_builder.models import (
11
+ AuxiliaryRequest,
12
+ HttpRequest,
13
+ HttpResponse,
14
+ StreamReadPages,
15
+ StreamReadSlices,
16
+ )
17
+ from airbyte_cdk.models import (
18
+ AirbyteLogMessage,
19
+ AirbyteMessage,
20
+ OrchestratorType,
21
+ TraceType,
22
+ )
23
+ from airbyte_cdk.models import Type as MessageType
24
+ from airbyte_cdk.sources.utils.slice_logger import SliceLogger
25
+ from airbyte_cdk.sources.utils.types import JsonType
26
+ from airbyte_cdk.utils.datetime_format_inferrer import DatetimeFormatInferrer
27
+ from airbyte_cdk.utils.schema_inferrer import (
28
+ SchemaInferrer,
29
+ )
30
+
31
+ from .types import LOG_MESSAGES_OUTPUT_TYPE
32
+
33
+ # -------
34
+ # Parsers
35
+ # -------
36
+
37
+
38
+ def airbyte_message_to_json(message: AirbyteMessage) -> Optional[Dict[str, JsonType]]:
39
+ """
40
+ Converts an AirbyteMessage to a JSON dictionary if its type is LOG.
41
+
42
+ This function attempts to parse the 'log' field of the given AirbyteMessage when its type is MessageType.LOG.
43
+ If the parsed JSON object exists but is not a dictionary, a ValueError is raised. If the message is not of type LOG,
44
+ the function returns None.
45
+
46
+ Parameters:
47
+ message (AirbyteMessage): The AirbyteMessage instance containing the log data.
48
+
49
+ Returns:
50
+ Optional[Dict[str, JsonType]]: The parsed log message as a dictionary if the message type is LOG, otherwise None.
51
+
52
+ Raises:
53
+ ValueError: If the parsed log message is not a dictionary.
54
+ """
55
+ if is_log_message(message):
56
+ json_object = parse_json(message.log) # type: ignore
57
+
58
+ if json_object is not None and not isinstance(json_object, dict):
59
+ raise ValueError(
60
+ f"Expected log message to be a dict, got {json_object} of type {type(json_object)}"
61
+ )
62
+
63
+ return json_object
64
+ return None
65
+
66
+
67
+ def clean_config(config: Dict[str, Any]) -> Dict[str, Any]:
68
+ """
69
+ Cleans the configuration dictionary by removing all keys that start with a double underscore.
70
+
71
+ This function creates a deep copy of the provided configuration dictionary and iterates
72
+ over its keys, deleting any key that begins with '__'. This is useful for filtering out
73
+ internal or meta-data fields that are not meant to be part of the final configuration.
74
+
75
+ Args:
76
+ config (Dict[str, Any]): The input configuration dictionary containing various key-value pairs.
77
+
78
+ Returns:
79
+ Dict[str, Any]: A deep copy of the original configuration with keys starting with '__' removed.
80
+ """
81
+ cleaned_config = deepcopy(config)
82
+ for key in config.keys():
83
+ if key.startswith("__"):
84
+ del cleaned_config[key]
85
+ return cleaned_config
86
+
87
+
88
+ def create_request_from_log_message(json_http_message: Dict[str, Any]) -> HttpRequest:
89
+ """
90
+ Creates an HttpRequest object from the provided JSON-formatted log message.
91
+
92
+ This function parses a dictionary that represents a logged HTTP message, extracting the URL, HTTP method,
93
+ headers, and body from nested dictionary structures. It is assumed that the expected keys and nested keys exist
94
+ or default values are used.
95
+
96
+ Parameters:
97
+ json_http_message (Dict[str, Any]):
98
+ A dictionary containing log message details with the following expected structure:
99
+ {
100
+ "url": {
101
+ "full": "<full_url>"
102
+ },
103
+ "http": {
104
+ "request": {
105
+ "method": "<HTTP_method>",
106
+ "headers": <headers>,
107
+ "body": {
108
+ "content": "<body_content>"
109
+ }
110
+ }
111
+ }
112
+ }
113
+
114
+ Returns:
115
+ HttpRequest:
116
+ An HttpRequest instance initialized with:
117
+ - url: Extracted from json_http_message["url"]["full"], defaults to an empty string if missing.
118
+ - http_method: Extracted from json_http_message["http"]["request"]["method"], defaults to an empty string if missing.
119
+ - headers: Extracted from json_http_message["http"]["request"]["headers"].
120
+ - body: Extracted from json_http_message["http"]["request"]["body"]["content"], defaults to an empty string if missing.
121
+ """
122
+ url = json_http_message.get("url", {}).get("full", "")
123
+ request = json_http_message.get("http", {}).get("request", {})
124
+ return HttpRequest(
125
+ url=url,
126
+ http_method=request.get("method", ""),
127
+ headers=request.get("headers"),
128
+ body=request.get("body", {}).get("content", ""),
129
+ )
130
+
131
+
132
+ def create_response_from_log_message(json_http_message: Dict[str, Any]) -> HttpResponse:
133
+ """
134
+ Generate an HttpResponse instance from a JSON log message containing HTTP response details.
135
+
136
+ Parameters:
137
+ json_http_message (Dict[str, Any]): A dictionary representing a JSON-encoded HTTP message.
138
+ It should include an "http" key with a nested "response" dictionary that contains:
139
+ - "status_code": The HTTP status code.
140
+ - "body": A dictionary with a "content" key for the response body.
141
+ - "headers": The HTTP response headers.
142
+
143
+ Returns:
144
+ HttpResponse: An HttpResponse object constructed from the extracted status code, body content, and headers.
145
+ """
146
+ response = json_http_message.get("http", {}).get("response", {})
147
+ body = response.get("body", {}).get("content", "")
148
+ return HttpResponse(
149
+ status=response.get("status_code"), body=body, headers=response.get("headers")
150
+ )
151
+
152
+
153
+ def parse_json(log_message: AirbyteLogMessage) -> JsonType:
154
+ """
155
+ Parse and extract a JSON object from an Airbyte log message.
156
+
157
+ This function attempts to decode the JSON string contained in the message field
158
+ of the provided AirbyteLogMessage instance. If the decoding process fails due to
159
+ malformed JSON, the function returns None.
160
+
161
+ Args:
162
+ log_message (AirbyteLogMessage): A log message object containing a JSON-formatted string in its 'message' attribute.
163
+
164
+ Returns:
165
+ JsonType: The parsed JSON object if decoding is successful; otherwise, None.
166
+ """
167
+ # TODO: As a temporary stopgap, the CDK emits request/response data as a log message string. Ideally this should come in the
168
+ # form of a custom message object defined in the Airbyte protocol, but this unblocks us in the immediate while the
169
+ # protocol change is worked on.
170
+ try:
171
+ json_object: JsonType = json.loads(log_message.message)
172
+ return json_object
173
+ except JSONDecodeError:
174
+ return None
175
+
176
+
177
+ def parse_slice_description(log_message: str) -> Dict[str, Any]:
178
+ """
179
+ Parses a log message containing a JSON payload and returns it as a dictionary.
180
+
181
+ The function removes a predefined logging prefix (defined by the constant
182
+ SliceLogger.SLICE_LOG_PREFIX) from the beginning of the log message and then
183
+ parses the remaining string as JSON.
184
+
185
+ Parameters:
186
+ log_message (str): The log message string that includes the JSON payload,
187
+ prefixed by SliceLogger.SLICE_LOG_PREFIX.
188
+
189
+ Returns:
190
+ Dict[str, Any]: A dictionary resulting from parsing the modified log message.
191
+
192
+ Raises:
193
+ json.JSONDecodeError: If the log message (after prefix removal) is not a valid JSON.
194
+ """
195
+ return json.loads(log_message.replace(SliceLogger.SLICE_LOG_PREFIX, "", 1)) # type: ignore
196
+
197
+
198
+ # -------
199
+ # Conditions
200
+ # -------
201
+
202
+
203
+ def should_close_page(
204
+ at_least_one_page_in_group: bool,
205
+ message: AirbyteMessage,
206
+ json_message: Optional[Dict[str, Any]],
207
+ ) -> bool:
208
+ """
209
+ Determines whether a page should be closed based on its content and state.
210
+
211
+ Args:
212
+ at_least_one_page_in_group (bool): Indicates if there is at least one page in the group.
213
+ message (AirbyteMessage): The message object containing details such as type and log information.
214
+ json_message (Optional[Dict[str, Any]]): A JSON representation of the message that may provide additional context,
215
+ particularly for HTTP requests.
216
+
217
+ Returns:
218
+ bool: True if all of the following conditions are met:
219
+ - There is at least one page in the group.
220
+ - The message type is MessageType.LOG.
221
+ - Either the JSON message corresponds to a page HTTP request (as determined by _is_page_http_request)
222
+ or the log message starts with "slice:".
223
+ Otherwise, returns False.
224
+ """
225
+ return (
226
+ at_least_one_page_in_group
227
+ and is_log_message(message)
228
+ and (
229
+ is_page_http_request(json_message) or message.log.message.startswith("slice:") # type: ignore[union-attr] # AirbyteMessage with MessageType.LOG has log.message
230
+ )
231
+ )
232
+
233
+
234
+ def should_process_slice_descriptor(message: AirbyteMessage) -> bool:
235
+ """
236
+ Determines whether the given AirbyteMessage should be processed as a slice descriptor.
237
+
238
+ This function checks if the message is a log message and if its log content starts with the
239
+ specific slice log prefix. It is used to filter out messages that represent slice descriptors
240
+ for further processing.
241
+
242
+ Parameters:
243
+ message (AirbyteMessage): The message to evaluate.
244
+
245
+ Returns:
246
+ bool: True if the message is a log message whose log message starts with the predefined
247
+ slice log prefix, indicating it is a slice descriptor; otherwise, False.
248
+ """
249
+ return is_log_message(message) and message.log.message.startswith( # type: ignore
250
+ SliceLogger.SLICE_LOG_PREFIX
251
+ )
252
+
253
+
254
+ def should_close_page_for_slice(at_least_one_page_in_group: bool, message: AirbyteMessage) -> bool:
255
+ """
256
+ Determines whether the current slice page should be closed.
257
+
258
+ This function checks if there is at least one page in the current group and if further processing
259
+ of the slice descriptor is required based on the provided Airbyte message.
260
+
261
+ Args:
262
+ at_least_one_page_in_group (bool): Indicates if at least one page already exists in the slice group.
263
+ message (AirbyteMessage): The message containing the slice descriptor information to be evaluated.
264
+
265
+ Returns:
266
+ bool: True if both conditions are met and the slice page needs to be closed; otherwise, False.
267
+ """
268
+ return at_least_one_page_in_group and should_process_slice_descriptor(message)
269
+
270
+
271
+ def is_page_http_request(json_message: Optional[Dict[str, Any]]) -> bool:
272
+ """
273
+ Determines whether a given JSON message represents a page HTTP request.
274
+
275
+ This function checks if the provided JSON message qualifies as a page HTTP request by verifying that:
276
+ 1. The JSON message exists.
277
+ 2. The JSON message is recognized as a valid HTTP log.
278
+ 3. The JSON message is not classified as an auxiliary HTTP request.
279
+
280
+ Args:
281
+ json_message (Optional[Dict[str, Any]]): A dictionary containing the JSON message to be evaluated.
282
+ If None or empty, the message will not be considered a page HTTP request.
283
+
284
+ Returns:
285
+ bool: True if the JSON message is a valid HTTP log and not an auxiliary HTTP request; otherwise, False.
286
+ """
287
+ if not json_message:
288
+ return False
289
+ else:
290
+ return is_http_log(json_message) and not is_auxiliary_http_request(json_message)
291
+
292
+
293
+ def is_http_log(message: Dict[str, JsonType]) -> bool:
294
+ """
295
+ Determine if the provided log message represents an HTTP log.
296
+
297
+ This function inspects the given message dictionary for the presence of the "http" key.
298
+ If the key exists and its value is truthy, the function interprets the message as an HTTP log.
299
+
300
+ Args:
301
+ message (Dict[str, JsonType]): A dictionary containing log data. It may include an "http" key
302
+ whose truthy value indicates an HTTP log.
303
+
304
+ Returns:
305
+ bool: True if the message is an HTTP log (i.e., "http" exists and is truthy); otherwise, False.
306
+ """
307
+ return bool(message.get("http", False))
308
+
309
+
310
+ def is_auxiliary_http_request(message: Optional[Dict[str, Any]]) -> bool:
311
+ """
312
+ Determines if the provided message represents an auxiliary HTTP request.
313
+
314
+ A auxiliary request is a request that is performed and will not directly lead to record for the specific stream it is being queried.
315
+
316
+ A couple of examples are:
317
+ * OAuth authentication
318
+ * Substream slice generation
319
+
320
+ Parameters:
321
+ message (Optional[Dict[str, Any]]): A dictionary representing a log message for an HTTP request.
322
+ The dictionary may contain nested keys indicating whether the request is auxiliary.
323
+
324
+ Returns:
325
+ bool: True if the message is an HTTP log and indicates an auxiliary request; otherwise, False.
326
+ """
327
+ if not message:
328
+ return False
329
+
330
+ return is_http_log(message) and message.get("http", {}).get("is_auxiliary", False)
331
+
332
+
333
+ def is_log_message(message: AirbyteMessage) -> bool:
334
+ """
335
+ Determines whether the provided message is of type LOG.
336
+
337
+ Args:
338
+ message (AirbyteMessage): The message to evaluate.
339
+
340
+ Returns:
341
+ bool: True if the message's type is LOG, otherwise False.
342
+ """
343
+ return message.type == MessageType.LOG # type: ignore
344
+
345
+
346
+ def is_trace_with_error(message: AirbyteMessage) -> bool:
347
+ """
348
+ Determines whether the provided AirbyteMessage is a TRACE message with an error.
349
+
350
+ This function checks if the message's type is TRACE and that its trace component is of type ERROR.
351
+
352
+ Parameters:
353
+ message (AirbyteMessage): The Airbyte message to be evaluated.
354
+
355
+ Returns:
356
+ bool: True if the message is a TRACE message with an error, False otherwise.
357
+ """
358
+ return message.type == MessageType.TRACE and message.trace.type == TraceType.ERROR # type: ignore
359
+
360
+
361
+ def is_record_message(message: AirbyteMessage) -> bool:
362
+ """
363
+ Determines whether the provided Airbyte message represents a record.
364
+
365
+ Parameters:
366
+ message (AirbyteMessage): The message instance to check. It should include a 'type' attribute that is comparable to MessageType.RECORD.
367
+
368
+ Returns:
369
+ bool: True if the message type is RECORD, otherwise False.
370
+ """
371
+ return message.type == MessageType.RECORD # type: ignore
372
+
373
+
374
+ def is_config_update_message(message: AirbyteMessage) -> bool:
375
+ """
376
+ Determine whether the provided AirbyteMessage represents a connector configuration update.
377
+
378
+ This function evaluates if the message is a control message and if its control type
379
+ matches that of a connector configuration update (i.e., OrchestratorType.CONNECTOR_CONFIG).
380
+ It is primarily used to filter messages related to configuration updates in the data pipeline.
381
+
382
+ Parameters:
383
+ message (AirbyteMessage): The message object to be evaluated.
384
+
385
+ Returns:
386
+ bool: True if the message is a connector configuration update message, False otherwise.
387
+ """
388
+ return ( # type: ignore
389
+ message.type == MessageType.CONTROL
390
+ and message.control.type == OrchestratorType.CONNECTOR_CONFIG # type: ignore
391
+ )
392
+
393
+
394
+ def is_state_message(message: AirbyteMessage) -> bool:
395
+ """
396
+ Determines whether the provided AirbyteMessage is a state message.
397
+
398
+ Parameters:
399
+ message (AirbyteMessage): The message to inspect.
400
+
401
+ Returns:
402
+ bool: True if the message's type is MessageType.STATE, False otherwise.
403
+ """
404
+ return message.type == MessageType.STATE # type: ignore
405
+
406
+
407
+ # -------
408
+ # Handlers
409
+ # -------
410
+
411
+
412
+ def handle_current_slice(
413
+ current_slice_pages: List[StreamReadPages],
414
+ current_slice_descriptor: Optional[Dict[str, Any]] = None,
415
+ latest_state_message: Optional[Dict[str, Any]] = None,
416
+ ) -> StreamReadSlices:
417
+ """
418
+ Handles the current slice by packaging its pages, descriptor, and state into a StreamReadSlices instance.
419
+
420
+ Args:
421
+ current_slice_pages (List[StreamReadPages]): The pages to be included in the slice.
422
+ current_slice_descriptor (Optional[Dict[str, Any]]): Descriptor for the current slice, optional.
423
+ latest_state_message (Optional[Dict[str, Any]]): The latest state message, optional.
424
+
425
+ Returns:
426
+ StreamReadSlices: An object containing the current slice's pages, descriptor, and state.
427
+ """
428
+ return StreamReadSlices(
429
+ pages=current_slice_pages,
430
+ slice_descriptor=current_slice_descriptor,
431
+ state=[latest_state_message] if latest_state_message else [],
432
+ )
433
+
434
+
435
+ def handle_current_page(
436
+ current_page_request: Optional[HttpRequest],
437
+ current_page_response: Optional[HttpResponse],
438
+ current_slice_pages: List[StreamReadPages],
439
+ current_page_records: List[Mapping[str, Any]],
440
+ ) -> tuple[None, None]:
441
+ """
442
+ Closes the current page by appending its request, response, and records
443
+ to the list of pages and clearing the current page records.
444
+
445
+ Args:
446
+ current_page_request (Optional[HttpRequest]): The HTTP request associated with the current page.
447
+ current_page_response (Optional[HttpResponse]): The HTTP response associated with the current page.
448
+ current_slice_pages (List[StreamReadPages]): A list to append the current page information.
449
+ current_page_records (List[Mapping[str, Any]]): The records of the current page to be cleared after processing.
450
+
451
+ Returns:
452
+ tuple[None, None]: A tuple indicating that no values are returned.
453
+ """
454
+
455
+ current_slice_pages.append(
456
+ StreamReadPages(
457
+ request=current_page_request,
458
+ response=current_page_response,
459
+ records=deepcopy(current_page_records), # type: ignore [arg-type]
460
+ )
461
+ )
462
+ current_page_records.clear()
463
+
464
+ return None, None
465
+
466
+
467
+ def handle_auxiliary_request(json_message: Dict[str, JsonType]) -> AuxiliaryRequest:
468
+ """
469
+ Parses the provided JSON message and constructs an AuxiliaryRequest object by extracting
470
+ relevant fields from nested dictionaries.
471
+
472
+ This function retrieves and validates the "airbyte_cdk", "stream", and "http" dictionaries
473
+ from the JSON message. It raises a ValueError if any of these are not of type dict. A title
474
+ is dynamically created by checking if the stream is a substream and then combining a prefix
475
+ with the "title" field from the "http" dictionary. The function also uses helper functions
476
+ to generate the request and response portions of the AuxiliaryRequest.
477
+
478
+ Parameters:
479
+ json_message (Dict[str, JsonType]): A dictionary representing the JSON log message containing
480
+ auxiliary request details.
481
+
482
+ Returns:
483
+ AuxiliaryRequest: An object containing the formatted title, description, request, and response
484
+ extracted from the JSON message.
485
+
486
+ Raises:
487
+ ValueError: If any of the "airbyte_cdk", "stream", or "http" fields is not a dictionary.
488
+ """
489
+ airbyte_cdk = json_message.get("airbyte_cdk", {})
490
+
491
+ if not isinstance(airbyte_cdk, dict):
492
+ raise ValueError(
493
+ f"Expected airbyte_cdk to be a dict, got {airbyte_cdk} of type {type(airbyte_cdk)}"
494
+ )
495
+
496
+ stream = airbyte_cdk.get("stream", {})
497
+
498
+ if not isinstance(stream, dict):
499
+ raise ValueError(f"Expected stream to be a dict, got {stream} of type {type(stream)}")
500
+
501
+ title_prefix = "Parent stream: " if stream.get("is_substream", False) else ""
502
+ http = json_message.get("http", {})
503
+
504
+ if not isinstance(http, dict):
505
+ raise ValueError(f"Expected http to be a dict, got {http} of type {type(http)}")
506
+
507
+ return AuxiliaryRequest(
508
+ title=title_prefix + str(http.get("title", None)),
509
+ description=str(http.get("description", None)),
510
+ request=create_request_from_log_message(json_message),
511
+ response=create_response_from_log_message(json_message),
512
+ )
513
+
514
+
515
+ def handle_log_message(
516
+ message: AirbyteMessage,
517
+ json_message: Dict[str, JsonType] | None,
518
+ at_least_one_page_in_group: bool,
519
+ current_page_request: Optional[HttpRequest],
520
+ current_page_response: Optional[HttpResponse],
521
+ ) -> LOG_MESSAGES_OUTPUT_TYPE:
522
+ """
523
+ Process a log message by handling both HTTP-specific and auxiliary log entries.
524
+
525
+ Parameters:
526
+ message (AirbyteMessage): The original log message received.
527
+ json_message (Dict[str, JsonType] | None): A parsed JSON representation of the log message, if available.
528
+ at_least_one_page_in_group (bool): Indicates whether at least one page within the group has been processed.
529
+ current_page_request (Optional[HttpRequest]): The HTTP request object corresponding to the current page, if any.
530
+ current_page_response (Optional[HttpResponse]): The HTTP response object corresponding to the current page, if any.
531
+
532
+ Returns:
533
+ LOG_MESSAGES_OUTPUT_TYPE: A tuple containing:
534
+ - A boolean flag that determines whether the group contains at least one page.
535
+ - An updated HttpRequest for the current page (if applicable).
536
+ - An updated HttpResponse for the current page (if applicable).
537
+ - The auxiliary log message, which might be the original HTTP log or another log field.
538
+
539
+ Note:
540
+ If the parsed JSON message indicates an HTTP log and represents an auxiliary HTTP request,
541
+ the auxiliary log is handled via _handle_auxiliary_request. Otherwise, if the JSON log is a standard HTTP log,
542
+ the function updates the current page's request and response objects by generating them from the log message.
543
+ """
544
+ auxiliary_request = None
545
+ log_message = None
546
+
547
+ if json_message is not None and is_http_log(json_message):
548
+ if is_auxiliary_http_request(json_message):
549
+ auxiliary_request = handle_auxiliary_request(json_message)
550
+ else:
551
+ at_least_one_page_in_group = True
552
+ current_page_request = create_request_from_log_message(json_message)
553
+ current_page_response = create_response_from_log_message(json_message)
554
+ else:
555
+ log_message = message.log
556
+
557
+ return (
558
+ at_least_one_page_in_group,
559
+ current_page_request,
560
+ current_page_response,
561
+ auxiliary_request or log_message,
562
+ )
563
+
564
+
565
+ def handle_record_message(
566
+ message: AirbyteMessage,
567
+ schema_inferrer: SchemaInferrer,
568
+ datetime_format_inferrer: DatetimeFormatInferrer,
569
+ records_count: int,
570
+ current_page_records: List[Mapping[str, Any]],
571
+ ) -> int:
572
+ """
573
+ Processes an Airbyte record message by updating the current batch and accumulating schema and datetime format information.
574
+
575
+ Parameters:
576
+ message (AirbyteMessage): The Airbyte message to process. Expected to have a 'type' attribute and, if of type RECORD, a 'record' attribute containing the record data.
577
+ schema_inferrer (SchemaInferrer): An instance responsible for inferring and accumulating schema details based on the record data.
578
+ datetime_format_inferrer (DatetimeFormatInferrer): An instance responsible for inferring and accumulating datetime format information from the record data.
579
+ records_count (int): The current count of processed records. This value is incremented if the message is a record.
580
+ current_page_records (List[Mapping[str, Any]]): A list where the data of processed record messages is accumulated.
581
+
582
+ Returns:
583
+ int: The updated record count after processing the message.
584
+ """
585
+ if message.type == MessageType.RECORD:
586
+ current_page_records.append(message.record.data) # type: ignore
587
+ records_count += 1
588
+ schema_inferrer.accumulate(message.record) # type: ignore
589
+ datetime_format_inferrer.accumulate(message.record) # type: ignore
590
+
591
+ return records_count