querysource 4.3.0__tar.gz → 4.4.2__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 (629) hide show
  1. querysource-4.4.2/.pre-commit-config.yaml +21 -0
  2. {querysource-4.3.0 → querysource-4.4.2}/PKG-INFO +1 -1
  3. querysource-4.4.2/generated/DropCols.json +109 -0
  4. querysource-4.4.2/generated/Filter.json +174 -0
  5. querysource-4.4.2/generated/FilterCols.json +38 -0
  6. querysource-4.4.2/generated/Forecast.json +184 -0
  7. querysource-4.4.2/generated/GoogleMaps.json +82 -0
  8. querysource-4.4.2/generated/GroupBy.json +106 -0
  9. querysource-4.4.2/generated/Join.json +149 -0
  10. querysource-4.4.2/generated/Map.json +228 -0
  11. querysource-4.4.2/generated/Melt.json +93 -0
  12. querysource-4.4.2/generated/Merge.json +137 -0
  13. querysource-4.4.2/generated/PluckCols.json +109 -0
  14. {querysource-4.3.0 → querysource-4.4.2}/generated/Query.json +32 -8
  15. querysource-4.4.2/generated/correlation.json +125 -0
  16. querysource-4.4.2/generated/crosstab.json +132 -0
  17. querysource-4.4.2/generated/pivot.json +166 -0
  18. querysource-4.4.2/generated/tExplode.json +84 -0
  19. querysource-4.4.2/generated/tOrder.json +99 -0
  20. {querysource-4.3.0 → querysource-4.4.2}/pyproject.toml +1 -1
  21. {querysource-4.3.0 → querysource-4.4.2}/qs-parser/Cargo.lock +12 -12
  22. {querysource-4.3.0 → querysource-4.4.2}/qs-parser/Cargo.toml +1 -1
  23. {querysource-4.3.0 → querysource-4.4.2}/querysource/_version.py +3 -3
  24. {querysource-4.3.0 → querysource-4.4.2}/querysource/conf.py +41 -0
  25. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/multi.py +37 -8
  26. querysource-4.4.2/querysource/handlers/scheduler.py +307 -0
  27. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/json.py +16 -0
  28. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/bigquery.c +1241 -1228
  29. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/bigquery.pyx +2 -1
  30. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/__init__.py +105 -33
  31. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/_introspect.py +267 -5
  32. querysource-4.4.2/querysource/queries/multi/operators/GroupBy.catalog.yaml +99 -0
  33. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/GroupBy.py +13 -0
  34. querysource-4.4.2/querysource/queries/multi/operators/Join.catalog.yaml +151 -0
  35. querysource-4.4.2/querysource/queries/multi/operators/Melt.catalog.yaml +105 -0
  36. querysource-4.4.2/querysource/queries/multi/operators/Merge.catalog.yaml +113 -0
  37. querysource-4.4.2/querysource/queries/multi/operators/filter/Filter.catalog.yaml +169 -0
  38. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/filter/flt.py +28 -3
  39. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/registry.py +23 -23
  40. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/sources/__init__.py +5 -0
  41. querysource-4.4.2/querysource/queries/multi/sources/executors.py +224 -0
  42. querysource-4.4.2/querysource/queries/multi/sources/query.catalog.yaml +111 -0
  43. querysource-4.4.2/querysource/queries/multi/sources/query.py +86 -0
  44. querysource-4.4.2/querysource/queries/multi/transformations/DropCols.catalog.yaml +78 -0
  45. querysource-4.4.2/querysource/queries/multi/transformations/FilterCols.catalog.yaml +43 -0
  46. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/FilterCols.py +10 -0
  47. querysource-4.4.2/querysource/queries/multi/transformations/Forecast.catalog.yaml +149 -0
  48. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/Forecast.py +15 -1
  49. querysource-4.4.2/querysource/queries/multi/transformations/Map.catalog.yaml +102 -0
  50. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/Map.py +27 -8
  51. querysource-4.4.2/querysource/queries/multi/transformations/PluckCols.catalog.yaml +78 -0
  52. querysource-4.4.2/querysource/queries/multi/transformations/correlation.catalog.yaml +105 -0
  53. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/correlation.py +1 -1
  54. querysource-4.4.2/querysource/queries/multi/transformations/crosstab.catalog.yaml +113 -0
  55. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/crosstab.py +1 -1
  56. querysource-4.4.2/querysource/queries/multi/transformations/google/GoogleMaps.catalog.yaml +83 -0
  57. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/google/maps.py +25 -5
  58. querysource-4.4.2/querysource/queries/multi/transformations/pivot.catalog.yaml +138 -0
  59. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/pivot.py +1 -1
  60. querysource-4.4.2/querysource/queries/multi/transformations/tExplode.catalog.yaml +81 -0
  61. querysource-4.4.2/querysource/queries/multi/transformations/tOrder.catalog.yaml +87 -0
  62. {querysource-4.3.0 → querysource-4.4.2}/querysource/scheduler/scheduler.py +231 -107
  63. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/dt/filters.py +23 -4
  64. {querysource-4.3.0 → querysource-4.4.2}/querysource/version.py +1 -1
  65. {querysource-4.3.0 → querysource-4.4.2}/querysource.egg-info/PKG-INFO +1 -1
  66. {querysource-4.3.0 → querysource-4.4.2}/querysource.egg-info/SOURCES.txt +35 -1
  67. {querysource-4.3.0 → querysource-4.4.2}/rust/src/validators.rs +34 -1
  68. querysource-4.4.2/tests/test_catalog_colcols.py +37 -0
  69. querysource-4.4.2/tests/test_catalog_correlation.py +30 -0
  70. querysource-4.4.2/tests/test_catalog_filter.py +84 -0
  71. querysource-4.4.2/tests/test_catalog_forecast.py +54 -0
  72. querysource-4.4.2/tests/test_catalog_googlemaps.py +47 -0
  73. querysource-4.4.2/tests/test_catalog_groupby.py +48 -0
  74. querysource-4.4.2/tests/test_catalog_map.py +74 -0
  75. querysource-4.4.2/tests/test_catalog_pivot.py +34 -0
  76. querysource-4.4.2/tests/test_catalog_remote.py +53 -0
  77. querysource-4.4.2/tests/test_catalog_texplode.py +28 -0
  78. querysource-4.4.2/tests/test_catalog_torder.py +29 -0
  79. {querysource-4.3.0 → querysource-4.4.2}/tests/test_column_filters.py +108 -0
  80. querysource-4.4.2/tests/test_local_executor.py +95 -0
  81. querysource-4.4.2/tests/test_multiqs_remote_dispatch.py +92 -0
  82. {querysource-4.3.0 → querysource-4.4.2}/tests/test_multiqs_sources_integration.py +13 -0
  83. querysource-4.4.2/tests/test_qworker_config.py +26 -0
  84. querysource-4.4.2/tests/test_remote_executor.py +107 -0
  85. querysource-4.4.2/tests/test_threadquery_executor.py +79 -0
  86. querysource-4.3.0/generated/DropCols.json +0 -58
  87. querysource-4.3.0/generated/Filter.json +0 -54
  88. querysource-4.3.0/generated/FilterCols.json +0 -28
  89. querysource-4.3.0/generated/Forecast.json +0 -68
  90. querysource-4.3.0/generated/GoogleMaps.json +0 -66
  91. querysource-4.3.0/generated/GroupBy.json +0 -48
  92. querysource-4.3.0/generated/Join.json +0 -62
  93. querysource-4.3.0/generated/Map.json +0 -28
  94. querysource-4.3.0/generated/Melt.json +0 -34
  95. querysource-4.3.0/generated/Merge.json +0 -58
  96. querysource-4.3.0/generated/PluckCols.json +0 -58
  97. querysource-4.3.0/generated/ThreadQuery.json +0 -10
  98. querysource-4.3.0/generated/correlation.json +0 -34
  99. querysource-4.3.0/generated/crosstab.json +0 -36
  100. querysource-4.3.0/generated/pivot.json +0 -60
  101. querysource-4.3.0/generated/tExplode.json +0 -68
  102. querysource-4.3.0/generated/tOrder.json +0 -62
  103. querysource-4.3.0/querysource/handlers/scheduler.py +0 -179
  104. querysource-4.3.0/querysource/queries/multi/sources/query.py +0 -177
  105. {querysource-4.3.0 → querysource-4.4.2}/.agent/rules/async-programming-expert.md +0 -0
  106. {querysource-4.3.0 → querysource-4.4.2}/.agent/rules/code-reviewer.md +0 -0
  107. {querysource-4.3.0 → querysource-4.4.2}/.agent/rules/cython-development.md +0 -0
  108. {querysource-4.3.0 → querysource-4.4.2}/.agent/rules/prompt-expert.md +0 -0
  109. {querysource-4.3.0 → querysource-4.4.2}/.agent/rules/python-development.md +0 -0
  110. {querysource-4.3.0 → querysource-4.4.2}/.agent/rules/rust-development.md +0 -0
  111. {querysource-4.3.0 → querysource-4.4.2}/.agent/workflows/create-parrot-tool.md +0 -0
  112. {querysource-4.3.0 → querysource-4.4.2}/.agent/workflows/create-workflow.md +0 -0
  113. {querysource-4.3.0 → querysource-4.4.2}/.agent/workflows/debug-regressions-with-git-bisect-binary-search.md +0 -0
  114. {querysource-4.3.0 → querysource-4.4.2}/.agent/workflows/generate-tests.md +0 -0
  115. {querysource-4.3.0 → querysource-4.4.2}/.agent/workflows/git-new-feature.md +0 -0
  116. {querysource-4.3.0 → querysource-4.4.2}/.agent/workflows/parrot-mcp-server.md +0 -0
  117. {querysource-4.3.0 → querysource-4.4.2}/.agent/workflows/release_package.md +0 -0
  118. {querysource-4.3.0 → querysource-4.4.2}/.agent/workflows/start-flow.md +0 -0
  119. {querysource-4.3.0 → querysource-4.4.2}/.bumpversion.cfg +0 -0
  120. {querysource-4.3.0 → querysource-4.4.2}/.claude/agents/code-reviewer.md +0 -0
  121. {querysource-4.3.0 → querysource-4.4.2}/.claude/agents/sdd-autopilot.md +0 -0
  122. {querysource-4.3.0 → querysource-4.4.2}/.claude/agents/sdd-qa.md +0 -0
  123. {querysource-4.3.0 → querysource-4.4.2}/.claude/agents/sdd-research.md +0 -0
  124. {querysource-4.3.0 → querysource-4.4.2}/.claude/agents/sdd-worker.md +0 -0
  125. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/pr-review.md +0 -0
  126. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-brainstorm.md +0 -0
  127. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-codereview.md +0 -0
  128. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-done.md +0 -0
  129. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-fromjira.md +0 -0
  130. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-next.md +0 -0
  131. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-proposal.md +0 -0
  132. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-spec.md +0 -0
  133. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-start.md +0 -0
  134. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-status.md +0 -0
  135. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-task.md +0 -0
  136. {querysource-4.3.0 → querysource-4.4.2}/.claude/commands/sdd-tojira.md +0 -0
  137. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/aws-cost-optimization.md +0 -0
  138. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/code-reviewer.md +0 -0
  139. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/cython-development.md +0 -0
  140. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/python-development.md +0 -0
  141. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/rust-development.md +0 -0
  142. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/using-git-worktrees.md +0 -0
  143. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/worktree-pr-and-clean.md +0 -0
  144. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/worktree-start-feature.md +0 -0
  145. {querysource-4.3.0 → querysource-4.4.2}/.claude/rules/worktree-status.md +0 -0
  146. {querysource-4.3.0 → querysource-4.4.2}/.github/dependabot.yml +0 -0
  147. {querysource-4.3.0 → querysource-4.4.2}/.github/workflows/codeql-analysis.yml +0 -0
  148. {querysource-4.3.0 → querysource-4.4.2}/.github/workflows/release.yml +0 -0
  149. {querysource-4.3.0 → querysource-4.4.2}/.isort.cfg +0 -0
  150. {querysource-4.3.0 → querysource-4.4.2}/.jupyter/jupyter_notebook_config.py +0 -0
  151. {querysource-4.3.0 → querysource-4.4.2}/.pylintrc +0 -0
  152. {querysource-4.3.0 → querysource-4.4.2}/CHANGES.rst +0 -0
  153. {querysource-4.3.0 → querysource-4.4.2}/CODE_OF_CONDUCT.md +0 -0
  154. {querysource-4.3.0 → querysource-4.4.2}/CONTRIBUTING.md +0 -0
  155. {querysource-4.3.0 → querysource-4.4.2}/INSTALL +0 -0
  156. {querysource-4.3.0 → querysource-4.4.2}/JOIN_CONDITIONS_FEATURE.md +0 -0
  157. {querysource-4.3.0 → querysource-4.4.2}/JOIN_CONDITIONS_SUMMARY.md +0 -0
  158. {querysource-4.3.0 → querysource-4.4.2}/LICENSE +0 -0
  159. {querysource-4.3.0 → querysource-4.4.2}/MANIFEST.in +0 -0
  160. {querysource-4.3.0 → querysource-4.4.2}/Makefile +0 -0
  161. {querysource-4.3.0 → querysource-4.4.2}/README.md +0 -0
  162. {querysource-4.3.0 → querysource-4.4.2}/app.py +0 -0
  163. {querysource-4.3.0 → querysource-4.4.2}/bin/README.md +0 -0
  164. {querysource-4.3.0 → querysource-4.4.2}/conftest.py +0 -0
  165. {querysource-4.3.0 → querysource-4.4.2}/generated/AirtableSource.json +0 -0
  166. {querysource-4.3.0 → querysource-4.4.2}/generated/Concat.json +0 -0
  167. {querysource-4.3.0 → querysource-4.4.2}/generated/DWHDestination.json +0 -0
  168. {querysource-4.3.0 → querysource-4.4.2}/generated/FileSource.json +0 -0
  169. {querysource-4.3.0 → querysource-4.4.2}/generated/Info.json +0 -0
  170. {querysource-4.3.0 → querysource-4.4.2}/generated/S3Source.json +0 -0
  171. {querysource-4.3.0 → querysource-4.4.2}/generated/SharepointSource.json +0 -0
  172. {querysource-4.3.0 → querysource-4.4.2}/generated/SmartSheetSource.json +0 -0
  173. {querysource-4.3.0 → querysource-4.4.2}/generated/Table.json +0 -0
  174. {querysource-4.3.0 → querysource-4.4.2}/generated/TableDestination.json +0 -0
  175. {querysource-4.3.0 → querysource-4.4.2}/generated/TableOutput.json +0 -0
  176. {querysource-4.3.0 → querysource-4.4.2}/generated/TableOutputAdapter.json +0 -0
  177. {querysource-4.3.0 → querysource-4.4.2}/generated/TableSource.json +0 -0
  178. {querysource-4.3.0 → querysource-4.4.2}/generated/ToS3.json +0 -0
  179. {querysource-4.3.0 → querysource-4.4.2}/generated/ToSharepoint.json +0 -0
  180. {querysource-4.3.0 → querysource-4.4.2}/generated/tPandas.json +0 -0
  181. {querysource-4.3.0 → querysource-4.4.2}/gunicorn_config.py +0 -0
  182. {querysource-4.3.0 → querysource-4.4.2}/mypy.ini +0 -0
  183. {querysource-4.3.0 → querysource-4.4.2}/nav.py +0 -0
  184. {querysource-4.3.0 → querysource-4.4.2}/policies/datasources.yaml +0 -0
  185. {querysource-4.3.0 → querysource-4.4.2}/policies/defaults.yaml +0 -0
  186. {querysource-4.3.0 → querysource-4.4.2}/policies/drivers.yaml +0 -0
  187. {querysource-4.3.0 → querysource-4.4.2}/policies/raw_queries.yaml +0 -0
  188. {querysource-4.3.0 → querysource-4.4.2}/policies/slugs.yaml +0 -0
  189. {querysource-4.3.0 → querysource-4.4.2}/policies/superusers.yaml +0 -0
  190. {querysource-4.3.0 → querysource-4.4.2}/pytest.ini +0 -0
  191. {querysource-4.3.0 → querysource-4.4.2}/qs-parser/pyproject.toml +0 -0
  192. {querysource-4.3.0 → querysource-4.4.2}/qs-parser/src/lib.rs +0 -0
  193. {querysource-4.3.0 → querysource-4.4.2}/qs-parser/src/parser.rs +0 -0
  194. {querysource-4.3.0 → querysource-4.4.2}/qs-parser/src/sql.rs +0 -0
  195. {querysource-4.3.0 → querysource-4.4.2}/querysource/__cli__.py +0 -0
  196. {querysource-4.3.0 → querysource-4.4.2}/querysource/__init__.py +0 -0
  197. {querysource-4.3.0 → querysource-4.4.2}/querysource/auth/__init__.py +0 -0
  198. {querysource-4.3.0 → querysource-4.4.2}/querysource/auth/_resource_types.py +0 -0
  199. {querysource-4.3.0 → querysource-4.4.2}/querysource/auth/credentials.py +0 -0
  200. {querysource-4.3.0 → querysource-4.4.2}/querysource/auth/pbac.py +0 -0
  201. {querysource-4.3.0 → querysource-4.4.2}/querysource/cache/__init__.py +0 -0
  202. {querysource-4.3.0 → querysource-4.4.2}/querysource/cache/backends/__init__.py +0 -0
  203. {querysource-4.3.0 → querysource-4.4.2}/querysource/cache/backends/abstract.py +0 -0
  204. {querysource-4.3.0 → querysource-4.4.2}/querysource/cache/backends/memcache.py +0 -0
  205. {querysource-4.3.0 → querysource-4.4.2}/querysource/cache/backends/redis.py +0 -0
  206. {querysource-4.3.0 → querysource-4.4.2}/querysource/cache/base.py +0 -0
  207. {querysource-4.3.0 → querysource-4.4.2}/querysource/cli/__init__.py +0 -0
  208. {querysource-4.3.0 → querysource-4.4.2}/querysource/cli/generate_docs.py +0 -0
  209. {querysource-4.3.0 → querysource-4.4.2}/querysource/connections.py +0 -0
  210. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/__init__.py +0 -0
  211. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/__init__.py +0 -0
  212. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/abstract.py +0 -0
  213. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/arangodb.py +0 -0
  214. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/athena.py +0 -0
  215. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/bigquery.py +0 -0
  216. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/cassandra.py +0 -0
  217. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/clickhouse.py +0 -0
  218. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/cockroachdb.py +0 -0
  219. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/couchbase.py +0 -0
  220. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/couchdb.py +0 -0
  221. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/countries.py +0 -0
  222. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/delta.py +0 -0
  223. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/documentdb.py +0 -0
  224. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/dynamodb.py +0 -0
  225. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/elastic.py +0 -0
  226. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/ga.py +0 -0
  227. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/gcalc.py +0 -0
  228. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/hazel.py +0 -0
  229. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/iceberg.py +0 -0
  230. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/influx.py +0 -0
  231. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/jdbc.py +0 -0
  232. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/jira.py +0 -0
  233. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/mariadb.py +0 -0
  234. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/memcached.py +0 -0
  235. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/mongo.py +0 -0
  236. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/mysql.py +0 -0
  237. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/odbc.py +0 -0
  238. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/openweather.py +0 -0
  239. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/oracle.py +0 -0
  240. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/pg.py +0 -0
  241. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/pg_admin.py +0 -0
  242. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/postgres.py +0 -0
  243. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/py.typed +0 -0
  244. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/qs.py +0 -0
  245. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/redis.py +0 -0
  246. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/rest.py +0 -0
  247. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/rethink.py +0 -0
  248. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/sa.py +0 -0
  249. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/salesforce.py +0 -0
  250. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/scylladb.py +0 -0
  251. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/sqlalchemy.py +0 -0
  252. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/sqlite.py +0 -0
  253. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/sqlserver.py +0 -0
  254. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/upc.py +0 -0
  255. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/drivers/zipcodeapi.py +0 -0
  256. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/handlers/__init__.py +0 -0
  257. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/handlers/datasource.py +0 -0
  258. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/handlers/utils.py +0 -0
  259. {querysource-4.3.0 → querysource-4.4.2}/querysource/datasources/models.py +0 -0
  260. {querysource-4.3.0 → querysource-4.4.2}/querysource/events/__init__.py +0 -0
  261. {querysource-4.3.0 → querysource-4.4.2}/querysource/exceptions.py +0 -0
  262. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/__init__.py +0 -0
  263. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/_pagination.py +0 -0
  264. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/abstract.py +0 -0
  265. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/components.py +0 -0
  266. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/executor.py +0 -0
  267. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/integrations/__init__.py +0 -0
  268. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/integrations/airtable.py +0 -0
  269. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/log.py +0 -0
  270. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/manager.py +0 -0
  271. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/outputs/__init__.py +0 -0
  272. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/outputs/tableOutput/__init__.py +0 -0
  273. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/outputs/tableOutput/postgres.py +0 -0
  274. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/outputs/tableOutput/table.py +0 -0
  275. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/service.py +0 -0
  276. {querysource-4.3.0 → querysource-4.4.2}/querysource/handlers/variables.py +0 -0
  277. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/__init__.py +0 -0
  278. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/airtable.py +0 -0
  279. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/connections.py +0 -0
  280. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/credentials.py +0 -0
  281. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/databases/__init__.py +0 -0
  282. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/databases/abstract.py +0 -0
  283. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/databases/bigquery.py +0 -0
  284. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/databases/db.py +0 -0
  285. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/databases/mongo.py +0 -0
  286. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/databases/rethink.py +0 -0
  287. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/http.py +0 -0
  288. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/playwright_service.py +0 -0
  289. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/queries.py +0 -0
  290. {querysource-4.3.0 → querysource-4.4.2}/querysource/interfaces/selenium_service.py +0 -0
  291. {querysource-4.3.0 → querysource-4.4.2}/querysource/libs/__init__.py +0 -0
  292. {querysource-4.3.0 → querysource-4.4.2}/querysource/libs/encoders.py +0 -0
  293. {querysource-4.3.0 → querysource-4.4.2}/querysource/libs/functions/__init__.py +0 -0
  294. {querysource-4.3.0 → querysource-4.4.2}/querysource/libs/py.typed +0 -0
  295. {querysource-4.3.0 → querysource-4.4.2}/querysource/models.py +0 -0
  296. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/__init__.py +0 -0
  297. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/destinations/__init__.py +0 -0
  298. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/destinations/abstract.py +0 -0
  299. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/destinations/dwh.py +0 -0
  300. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/destinations/s3.py +0 -0
  301. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/destinations/sharepoint.py +0 -0
  302. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/destinations/table.py +0 -0
  303. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/__init__.py +0 -0
  304. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/abstract.py +0 -0
  305. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/arrow.py +0 -0
  306. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/dt.py +0 -0
  307. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/factory.py +0 -0
  308. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/iter.py +0 -0
  309. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/modin.py +0 -0
  310. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/pandas.py +0 -0
  311. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/dt/polars.py +0 -0
  312. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/output.py +0 -0
  313. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/__init__.py +0 -0
  314. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/abstract.py +0 -0
  315. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/bigquery.py +0 -0
  316. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/documentdb.py +0 -0
  317. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/mongodb.py +0 -0
  318. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/mysql.py +0 -0
  319. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/postgres.py +0 -0
  320. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/rethink.py +0 -0
  321. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/sa.py +0 -0
  322. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/table.py +0 -0
  323. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/tables/__init__.py +0 -0
  324. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/__init__.py +0 -0
  325. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/abstract.py +0 -0
  326. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/bokeh.py +0 -0
  327. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/clustering.py +0 -0
  328. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/csv.py +0 -0
  329. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/describe.py +0 -0
  330. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/eda.py +0 -0
  331. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/excel.py +0 -0
  332. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/html.py +0 -0
  333. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/pdf.py +0 -0
  334. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/pickle.py +0 -0
  335. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/plotly.py +0 -0
  336. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/profiling.py +0 -0
  337. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/report.py +0 -0
  338. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/table.py +0 -0
  339. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/tsv.py +0 -0
  340. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/txt.py +0 -0
  341. {querysource-4.3.0 → querysource-4.4.2}/querysource/outputs/writers/xml.py +0 -0
  342. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/__init__.py +0 -0
  343. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/abstract.c +0 -0
  344. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/abstract.pxd +0 -0
  345. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/abstract.pyx +0 -0
  346. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/arangodb.c +0 -0
  347. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/arangodb.pxd +0 -0
  348. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/arangodb.pyx +0 -0
  349. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/bigquery.pxd +0 -0
  350. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/cql.c +0 -0
  351. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/cql.pxd +0 -0
  352. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/cql.pyx +0 -0
  353. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/deltatbl.c +0 -0
  354. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/deltatbl.pxd +0 -0
  355. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/deltatbl.pyx +0 -0
  356. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/elastic.cpp +0 -0
  357. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/elastic.pxd +0 -0
  358. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/elastic.pyx +0 -0
  359. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/iceberg.c +0 -0
  360. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/iceberg.pxd +0 -0
  361. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/iceberg.pyx +0 -0
  362. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/influx.c +0 -0
  363. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/influx.pxd +0 -0
  364. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/influx.pyx +0 -0
  365. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/mongo.cpp +0 -0
  366. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/mongo.pxd +0 -0
  367. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/mongo.pyx +0 -0
  368. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/parser.c +0 -0
  369. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/parser.pxd +0 -0
  370. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/parser.pyx +0 -0
  371. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/pgsql.c +0 -0
  372. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/pgsql.pxd +0 -0
  373. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/pgsql.pyx +0 -0
  374. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/rethink.c +0 -0
  375. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/rethink.pxd +0 -0
  376. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/rethink.pyx +0 -0
  377. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sosql.c +0 -0
  378. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sosql.pxd +0 -0
  379. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sosql.pyx +0 -0
  380. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sql.c +0 -0
  381. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sql.pxd +0 -0
  382. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sql.pyx +0 -0
  383. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sqlserver.c +0 -0
  384. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sqlserver.pxd +0 -0
  385. {querysource-4.3.0 → querysource-4.4.2}/querysource/parsers/sqlserver.pyx +0 -0
  386. {querysource-4.3.0 → querysource-4.4.2}/querysource/plugins/__init__.py +0 -0
  387. {querysource-4.3.0 → querysource-4.4.2}/querysource/plugins/importer.py +0 -0
  388. {querysource-4.3.0 → querysource-4.4.2}/querysource/plugins/sources/__init__.py +0 -0
  389. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/__init__.py +0 -0
  390. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/abstract.py +0 -0
  391. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/arangodb.py +0 -0
  392. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/bigquery.py +0 -0
  393. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/cassandra.py +0 -0
  394. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/db.py +0 -0
  395. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/default.py +0 -0
  396. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/deltatbl.py +0 -0
  397. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/documentdb.py +0 -0
  398. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/dummy.py +0 -0
  399. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/elastic.py +0 -0
  400. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/external.py +0 -0
  401. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/http.py +0 -0
  402. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/iceberg.py +0 -0
  403. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/influx.py +0 -0
  404. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/mysql.py +0 -0
  405. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/pg.py +0 -0
  406. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/py.typed +0 -0
  407. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/rest.py +0 -0
  408. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/rethink.py +0 -0
  409. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/salesforce.py +0 -0
  410. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/scylladb.py +0 -0
  411. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/__init__.py +0 -0
  412. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/abstract.py +0 -0
  413. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/amazon.py +0 -0
  414. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/countries.py +0 -0
  415. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/ga.py +0 -0
  416. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/geofcc.py +0 -0
  417. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/gmaps.py +0 -0
  418. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/graphcountries.py +0 -0
  419. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/graphql.py +0 -0
  420. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/http.py +0 -0
  421. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/hubspot.py +0 -0
  422. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/openweather.py +0 -0
  423. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/parsers/__init__.py +0 -0
  424. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/parsers/amproduct.py +0 -0
  425. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/parsers/xpath.py +0 -0
  426. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/pokemon.py +0 -0
  427. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/populartimes.py +0 -0
  428. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/py.typed +0 -0
  429. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/rest.py +0 -0
  430. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/retailnext.py +0 -0
  431. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/rssapp.py +0 -0
  432. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/salesforce.py +0 -0
  433. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/scrapper.py +0 -0
  434. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/shoppertrack.py +0 -0
  435. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/swop.py +0 -0
  436. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/uap.py +0 -0
  437. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/upc.py +0 -0
  438. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/wm_stores.py +0 -0
  439. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/zammad.py +0 -0
  440. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sources/zipcodeapi.py +0 -0
  441. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sql.py +0 -0
  442. {querysource-4.3.0 → querysource-4.4.2}/querysource/providers/sqlserver.py +0 -0
  443. {querysource-4.3.0 → querysource-4.4.2}/querysource/py.typed +0 -0
  444. {querysource-4.3.0 → querysource-4.4.2}/querysource/qs_parsers/__init__.py +0 -0
  445. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/__init__.py +0 -0
  446. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/base.py +0 -0
  447. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/executor.py +0 -0
  448. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/models.py +0 -0
  449. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/abstract.py +0 -0
  450. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/components/__init__.py +0 -0
  451. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/components/abstract.py +0 -0
  452. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/destinations/__init__.py +0 -0
  453. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/destinations/dwh.py +0 -0
  454. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/destinations/s3.py +0 -0
  455. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/destinations/sharepoint.py +0 -0
  456. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/destinations/table.py +0 -0
  457. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/Concat.py +0 -0
  458. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/Info.py +0 -0
  459. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/Join.py +0 -0
  460. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/Melt.py +0 -0
  461. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/Merge.py +0 -0
  462. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/__init__.py +0 -0
  463. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/abstract.py +0 -0
  464. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/operators/filter/__init__.py +0 -0
  465. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/sources/airtable.py +0 -0
  466. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/sources/base.py +0 -0
  467. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/sources/file.py +0 -0
  468. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/sources/s3.py +0 -0
  469. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/sources/sharepoint.py +0 -0
  470. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/sources/smartsheet.py +0 -0
  471. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/sources/table.py +0 -0
  472. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/DropCols.py +0 -0
  473. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/PluckCols.py +0 -0
  474. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/__init__.py +0 -0
  475. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/abstract.py +0 -0
  476. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/google/__init__.py +0 -0
  477. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/tExplode.py +0 -0
  478. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/tOrder.py +0 -0
  479. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/multi/transformations/tPandas.py +0 -0
  480. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/obj.py +0 -0
  481. {querysource-4.3.0 → querysource-4.4.2}/querysource/queries/qs.py +0 -0
  482. {querysource-4.3.0 → querysource-4.4.2}/querysource/scheduler/__init__.py +0 -0
  483. {querysource-4.3.0 → querysource-4.4.2}/querysource/scheduler/jobs.py +0 -0
  484. {querysource-4.3.0 → querysource-4.4.2}/querysource/scheduler/notifications.py +0 -0
  485. {querysource-4.3.0 → querysource-4.4.2}/querysource/services.py +0 -0
  486. {querysource-4.3.0 → querysource-4.4.2}/querysource/template/__init__.py +0 -0
  487. {querysource-4.3.0 → querysource-4.4.2}/querysource/template/parser.py +0 -0
  488. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/__init__.py +0 -0
  489. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/converters.cpp +0 -0
  490. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/converters.pyx +0 -0
  491. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/dt/__init__.py +0 -0
  492. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/dt/transforms.py +0 -0
  493. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/py.typed +0 -0
  494. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/typedefs.c +0 -0
  495. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/typedefs.pyx +0 -0
  496. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/validators.cpp +0 -0
  497. {querysource-4.3.0 → querysource-4.4.2}/querysource/types/validators.pyx +0 -0
  498. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/__init__.py +0 -0
  499. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/cache_serialization.py +0 -0
  500. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/events.py +0 -0
  501. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/fn.py +0 -0
  502. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/functions.cpp +0 -0
  503. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/functions.pyx +0 -0
  504. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/getfunc.py +0 -0
  505. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/handlers.py +0 -0
  506. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/parseqs.cpp +0 -0
  507. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/parseqs.pyx +0 -0
  508. {querysource-4.3.0 → querysource-4.4.2}/querysource/utils/validators.py +0 -0
  509. {querysource-4.3.0 → querysource-4.4.2}/querysource.egg-info/dependency_links.txt +0 -0
  510. {querysource-4.3.0 → querysource-4.4.2}/querysource.egg-info/entry_points.txt +0 -0
  511. {querysource-4.3.0 → querysource-4.4.2}/querysource.egg-info/not-zip-safe +0 -0
  512. {querysource-4.3.0 → querysource-4.4.2}/querysource.egg-info/requires.txt +0 -0
  513. {querysource-4.3.0 → querysource-4.4.2}/querysource.egg-info/top_level.txt +0 -0
  514. {querysource-4.3.0 → querysource-4.4.2}/run.py +0 -0
  515. {querysource-4.3.0 → querysource-4.4.2}/rust/Cargo.lock +0 -0
  516. {querysource-4.3.0 → querysource-4.4.2}/rust/Cargo.toml +0 -0
  517. {querysource-4.3.0 → querysource-4.4.2}/rust/pyproject.toml +0 -0
  518. {querysource-4.3.0 → querysource-4.4.2}/rust/src/arangodb_parser.rs +0 -0
  519. {querysource-4.3.0 → querysource-4.4.2}/rust/src/bigquery_parser.rs +0 -0
  520. {querysource-4.3.0 → querysource-4.4.2}/rust/src/cql_parser.rs +0 -0
  521. {querysource-4.3.0 → querysource-4.4.2}/rust/src/elastic_parser.rs +0 -0
  522. {querysource-4.3.0 → querysource-4.4.2}/rust/src/filter_common.rs +0 -0
  523. {querysource-4.3.0 → querysource-4.4.2}/rust/src/flux_parser.rs +0 -0
  524. {querysource-4.3.0 → querysource-4.4.2}/rust/src/lib.rs +0 -0
  525. {querysource-4.3.0 → querysource-4.4.2}/rust/src/mongo_parser.rs +0 -0
  526. {querysource-4.3.0 → querysource-4.4.2}/rust/src/mssql_parser.rs +0 -0
  527. {querysource-4.3.0 → querysource-4.4.2}/rust/src/parseqs.rs +0 -0
  528. {querysource-4.3.0 → querysource-4.4.2}/rust/src/pgsql_parser.rs +0 -0
  529. {querysource-4.3.0 → querysource-4.4.2}/rust/src/rethink_parser.rs +0 -0
  530. {querysource-4.3.0 → querysource-4.4.2}/rust/src/safe_dict.rs +0 -0
  531. {querysource-4.3.0 → querysource-4.4.2}/rust/src/soql_parser.rs +0 -0
  532. {querysource-4.3.0 → querysource-4.4.2}/rust/src/sql_parser.rs +0 -0
  533. {querysource-4.3.0 → querysource-4.4.2}/setup.cfg +0 -0
  534. {querysource-4.3.0 → querysource-4.4.2}/setup.py +0 -0
  535. {querysource-4.3.0 → querysource-4.4.2}/static/notebook/bundle.js +0 -0
  536. {querysource-4.3.0 → querysource-4.4.2}/templates/__init__.py +0 -0
  537. {querysource-4.3.0 → querysource-4.4.2}/templates/base.html +0 -0
  538. {querysource-4.3.0 → querysource-4.4.2}/templates/default.html +0 -0
  539. {querysource-4.3.0 → querysource-4.4.2}/templates/default_table.html +0 -0
  540. {querysource-4.3.0 → querysource-4.4.2}/templates/fontlist-v330.json +0 -0
  541. {querysource-4.3.0 → querysource-4.4.2}/templates/fontlist-v390.json +0 -0
  542. {querysource-4.3.0 → querysource-4.4.2}/templates/table_charts.html +0 -0
  543. {querysource-4.3.0 → querysource-4.4.2}/tests/auth/__init__.py +0 -0
  544. {querysource-4.3.0 → querysource-4.4.2}/tests/auth/test_credentials.py +0 -0
  545. {querysource-4.3.0 → querysource-4.4.2}/tests/auth/test_pbac_bootstrap.py +0 -0
  546. {querysource-4.3.0 → querysource-4.4.2}/tests/check_concurrent_get_slug.py +0 -0
  547. {querysource-4.3.0 → querysource-4.4.2}/tests/conftest.py +0 -0
  548. {querysource-4.3.0 → querysource-4.4.2}/tests/datasources/__init__.py +0 -0
  549. {querysource-4.3.0 → querysource-4.4.2}/tests/datasources/test_datasource_view_pbac.py +0 -0
  550. {querysource-4.3.0 → querysource-4.4.2}/tests/datasources/test_driver_factory_session.py +0 -0
  551. {querysource-4.3.0 → querysource-4.4.2}/tests/datasources/test_pg_admin_registration.py +0 -0
  552. {querysource-4.3.0 → querysource-4.4.2}/tests/datasources/test_pg_params_for.py +0 -0
  553. {querysource-4.3.0 → querysource-4.4.2}/tests/handlers/__init__.py +0 -0
  554. {querysource-4.3.0 → querysource-4.4.2}/tests/handlers/conftest.py +0 -0
  555. {querysource-4.3.0 → querysource-4.4.2}/tests/handlers/test_abstract_pbac_helpers.py +0 -0
  556. {querysource-4.3.0 → querysource-4.4.2}/tests/handlers/test_airtable_oauth.py +0 -0
  557. {querysource-4.3.0 → querysource-4.4.2}/tests/handlers/test_multiquery_pbac_smoke.py +0 -0
  558. {querysource-4.3.0 → querysource-4.4.2}/tests/handlers/test_queryexecutor_pbac_smoke.py +0 -0
  559. {querysource-4.3.0 → querysource-4.4.2}/tests/handlers/test_querymanager_pagination.py +0 -0
  560. {querysource-4.3.0 → querysource-4.4.2}/tests/handlers/test_queryservice_pbac_smoke.py +0 -0
  561. {querysource-4.3.0 → querysource-4.4.2}/tests/integration/__init__.py +0 -0
  562. {querysource-4.3.0 → querysource-4.4.2}/tests/integration/test_pbac_credentials.py +0 -0
  563. {querysource-4.3.0 → querysource-4.4.2}/tests/integration/test_pbac_enforcement.py +0 -0
  564. {querysource-4.3.0 → querysource-4.4.2}/tests/integration/test_pbac_listing.py +0 -0
  565. {querysource-4.3.0 → querysource-4.4.2}/tests/interfaces/__init__.py +0 -0
  566. {querysource-4.3.0 → querysource-4.4.2}/tests/interfaces/test_airtable_interface.py +0 -0
  567. {querysource-4.3.0 → querysource-4.4.2}/tests/multi/__init__.py +0 -0
  568. {querysource-4.3.0 → querysource-4.4.2}/tests/multi/sources/__init__.py +0 -0
  569. {querysource-4.3.0 → querysource-4.4.2}/tests/multi/sources/test_airtable_source.py +0 -0
  570. {querysource-4.3.0 → querysource-4.4.2}/tests/multi/sources/test_registry.py +0 -0
  571. {querysource-4.3.0 → querysource-4.4.2}/tests/perf/__init__.py +0 -0
  572. {querysource-4.3.0 → querysource-4.4.2}/tests/perf/test_pbac_overhead.py +0 -0
  573. {querysource-4.3.0 → querysource-4.4.2}/tests/policies/__init__.py +0 -0
  574. {querysource-4.3.0 → querysource-4.4.2}/tests/policies/test_default_policies_load.py +0 -0
  575. {querysource-4.3.0 → querysource-4.4.2}/tests/scheduler/__init__.py +0 -0
  576. {querysource-4.3.0 → querysource-4.4.2}/tests/scheduler/test_parse_trigger_shorthands.py +0 -0
  577. {querysource-4.3.0 → querysource-4.4.2}/tests/scheduler/test_shorthand_loaders.py +0 -0
  578. {querysource-4.3.0 → querysource-4.4.2}/tests/services/__init__.py +0 -0
  579. {querysource-4.3.0 → querysource-4.4.2}/tests/services/test_querysource_setup_pbac.py +0 -0
  580. {querysource-4.3.0 → querysource-4.4.2}/tests/test_abstract_multi.py +0 -0
  581. {querysource-4.3.0 → querysource-4.4.2}/tests/test_abstract_refactor.py +0 -0
  582. {querysource-4.3.0 → querysource-4.4.2}/tests/test_api.py +0 -0
  583. {querysource-4.3.0 → querysource-4.4.2}/tests/test_arangodb_parser.py +0 -0
  584. {querysource-4.3.0 → querysource-4.4.2}/tests/test_cli_generate_docs.py +0 -0
  585. {querysource-4.3.0 → querysource-4.4.2}/tests/test_component_handler.py +0 -0
  586. {querysource-4.3.0 → querysource-4.4.2}/tests/test_component_registry.py +0 -0
  587. {querysource-4.3.0 → querysource-4.4.2}/tests/test_conf_airtable.py +0 -0
  588. {querysource-4.3.0 → querysource-4.4.2}/tests/test_destination_base.py +0 -0
  589. {querysource-4.3.0 → querysource-4.4.2}/tests/test_destination_dwh.py +0 -0
  590. {querysource-4.3.0 → querysource-4.4.2}/tests/test_destination_integration.py +0 -0
  591. {querysource-4.3.0 → querysource-4.4.2}/tests/test_destination_s3.py +0 -0
  592. {querysource-4.3.0 → querysource-4.4.2}/tests/test_destination_sharepoint.py +0 -0
  593. {querysource-4.3.0 → querysource-4.4.2}/tests/test_destination_table.py +0 -0
  594. {querysource-4.3.0 → querysource-4.4.2}/tests/test_destinations_documentation_endpoint.py +0 -0
  595. {querysource-4.3.0 → querysource-4.4.2}/tests/test_elastic_parser.py +0 -0
  596. {querysource-4.3.0 → querysource-4.4.2}/tests/test_eval.py +0 -0
  597. {querysource-4.3.0 → querysource-4.4.2}/tests/test_info_eda.py +0 -0
  598. {querysource-4.3.0 → querysource-4.4.2}/tests/test_info_eda_e2e.py +0 -0
  599. {querysource-4.3.0 → querysource-4.4.2}/tests/test_info_eda_integration.py +0 -0
  600. {querysource-4.3.0 → querysource-4.4.2}/tests/test_join_conditions.py +0 -0
  601. {querysource-4.3.0 → querysource-4.4.2}/tests/test_join_with_column_filter.py +0 -0
  602. {querysource-4.3.0 → querysource-4.4.2}/tests/test_multi_destinations_subpackage.py +0 -0
  603. {querysource-4.3.0 → querysource-4.4.2}/tests/test_multiqs_column_transforms.py +0 -0
  604. {querysource-4.3.0 → querysource-4.4.2}/tests/test_multiqs_destination_dispatch.py +0 -0
  605. {querysource-4.3.0 → querysource-4.4.2}/tests/test_queryslug_concurrency.py +0 -0
  606. {querysource-4.3.0 → querysource-4.4.2}/tests/test_querysource_setup_airtable.py +0 -0
  607. {querysource-4.3.0 → querysource-4.4.2}/tests/test_route_registration.py +0 -0
  608. {querysource-4.3.0 → querysource-4.4.2}/tests/test_rss.py +0 -0
  609. {querysource-4.3.0 → querysource-4.4.2}/tests/test_rust_parsers.py +0 -0
  610. {querysource-4.3.0 → querysource-4.4.2}/tests/test_scheduler_core.py +0 -0
  611. {querysource-4.3.0 → querysource-4.4.2}/tests/test_scheduler_handler_integration.py +0 -0
  612. {querysource-4.3.0 → querysource-4.4.2}/tests/test_scheduler_handler_unit.py +0 -0
  613. {querysource-4.3.0 → querysource-4.4.2}/tests/test_scheduler_integration.py +0 -0
  614. {querysource-4.3.0 → querysource-4.4.2}/tests/test_scheduler_jobs.py +0 -0
  615. {querysource-4.3.0 → querysource-4.4.2}/tests/test_scheduler_multi_routing.py +0 -0
  616. {querysource-4.3.0 → querysource-4.4.2}/tests/test_scheduler_notifications.py +0 -0
  617. {querysource-4.3.0 → querysource-4.4.2}/tests/test_schema_introspectable.py +0 -0
  618. {querysource-4.3.0 → querysource-4.4.2}/tests/test_source_registry.py +0 -0
  619. {querysource-4.3.0 → querysource-4.4.2}/tests/test_source_s3.py +0 -0
  620. {querysource-4.3.0 → querysource-4.4.2}/tests/test_source_sharepoint.py +0 -0
  621. {querysource-4.3.0 → querysource-4.4.2}/tests/test_source_smartsheet.py +0 -0
  622. {querysource-4.3.0 → querysource-4.4.2}/tests/test_source_table.py +0 -0
  623. {querysource-4.3.0 → querysource-4.4.2}/tests/test_sql_parser_combinations.py +0 -0
  624. {querysource-4.3.0 → querysource-4.4.2}/tests/test_texplode.py +0 -0
  625. {querysource-4.3.0 → querysource-4.4.2}/tests/test_thread_file_refactor.py +0 -0
  626. {querysource-4.3.0 → querysource-4.4.2}/tests/test_thread_query_refactor.py +0 -0
  627. {querysource-4.3.0 → querysource-4.4.2}/tests/test_thread_source_base.py +0 -0
  628. {querysource-4.3.0 → querysource-4.4.2}/tests/test_zammad_search.py +0 -0
  629. {querysource-4.3.0 → querysource-4.4.2}/tox.ini +0 -0
@@ -0,0 +1,21 @@
1
+ # Pre-commit hooks for QuerySource.
2
+ #
3
+ # Install once per clone (inside the activated venv):
4
+ # uv pip install pre-commit
5
+ # pre-commit install
6
+ #
7
+ # The generate-multiquery-docs hook regenerates the per-component JSON under
8
+ # generated/ from the component classes + their <module>.catalog.yaml companion
9
+ # files. If anything changed, pre-commit re-stages the files and fails the
10
+ # commit so the refreshed docs are included — this is the freshness guard that
11
+ # stops generated/ from drifting out of sync with the source of truth.
12
+ repos:
13
+ - repo: local
14
+ hooks:
15
+ - id: generate-multiquery-docs
16
+ name: Regenerate MultiQuery component docs (generated/)
17
+ entry: bash -c 'generate-multiquery-docs -o generated >/dev/null && git add generated'
18
+ language: system
19
+ pass_filenames: false
20
+ always_run: true
21
+ stages: [pre-commit]
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: querysource
3
- Version: 4.3.0
3
+ Version: 4.4.2
4
4
  Summary: Aiohttp web service for querying several databases easily
5
5
  Author-email: Jesus Lara <jesuslarag@gmail.com>
6
6
  License: BSD-3-Clause
@@ -0,0 +1,109 @@
1
+ {
2
+ "name": "DropCols",
3
+ "category": "Transformations",
4
+ "description": "Drop the columns matching any of the provided selectors (blacklist by column name).",
5
+ "usage": "Provide at least one of ``columns`` (exact names), ``pattern`` (glob), ``regex``, ``startswith`` or ``endswith``. Matches from every selector are unioned and removed. Exact names in ``columns`` that are not present are silently ignored.",
6
+ "attributes": [
7
+ {
8
+ "name": "columns",
9
+ "type": "list",
10
+ "default": null,
11
+ "required": false,
12
+ "description": "Exact column names to drop. Missing columns are silently ignored."
13
+ },
14
+ {
15
+ "name": "pattern",
16
+ "type": "str",
17
+ "default": null,
18
+ "required": false,
19
+ "description": "Glob/fnmatch pattern to match column names (e.g. \"debug_*\")."
20
+ },
21
+ {
22
+ "name": "regex",
23
+ "type": "str",
24
+ "default": null,
25
+ "required": false,
26
+ "description": "Regular expression to match column names (e.g. \"^tmp_.*$\")."
27
+ },
28
+ {
29
+ "name": "startswith",
30
+ "type": "list",
31
+ "default": null,
32
+ "required": false,
33
+ "description": "Drop columns whose name starts with any of these prefixes."
34
+ },
35
+ {
36
+ "name": "endswith",
37
+ "type": "list",
38
+ "default": null,
39
+ "required": false,
40
+ "description": "Drop columns whose name ends with any of these suffixes."
41
+ }
42
+ ],
43
+ "json_schema": {
44
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
45
+ "title": "DropCols",
46
+ "type": "object",
47
+ "properties": {
48
+ "columns": {
49
+ "$ref": "#/$defs/stringList",
50
+ "description": "Exact column names to drop."
51
+ },
52
+ "pattern": {
53
+ "type": "string",
54
+ "description": "Glob/fnmatch pattern to match column names (e.g. \"debug_*\")."
55
+ },
56
+ "regex": {
57
+ "type": "string",
58
+ "description": "Regular expression to match column names (e.g. \"^tmp_.*$\")."
59
+ },
60
+ "startswith": {
61
+ "$ref": "#/$defs/stringList",
62
+ "description": "Prefixes; columns starting with any are dropped."
63
+ },
64
+ "endswith": {
65
+ "$ref": "#/$defs/stringList",
66
+ "description": "Suffixes; columns ending with any are dropped."
67
+ }
68
+ },
69
+ "anyOf": [
70
+ {
71
+ "required": [
72
+ "columns"
73
+ ]
74
+ },
75
+ {
76
+ "required": [
77
+ "pattern"
78
+ ]
79
+ },
80
+ {
81
+ "required": [
82
+ "regex"
83
+ ]
84
+ },
85
+ {
86
+ "required": [
87
+ "startswith"
88
+ ]
89
+ },
90
+ {
91
+ "required": [
92
+ "endswith"
93
+ ]
94
+ }
95
+ ],
96
+ "additionalProperties": true,
97
+ "description": "Drop columns matching any selector. At least one selector is required.",
98
+ "$defs": {
99
+ "stringList": {
100
+ "type": "array",
101
+ "items": {
102
+ "type": "string"
103
+ }
104
+ }
105
+ }
106
+ },
107
+ "example": "{\"Transform\": [{\"DropCols\": {\"columns\": [\"internal_id\", \"debug_flag\"]}}]}",
108
+ "icon": "shuffle"
109
+ }
@@ -0,0 +1,174 @@
1
+ {
2
+ "name": "Filter",
3
+ "category": "Operators",
4
+ "description": "Filter the rows of a DataFrame using declarative conditions, named filter functions, and/or column equality selection, combined with a logical AND/OR.",
5
+ "usage": "Provide any combination of: ``conditions``/``filter`` (a list of ``{column, expression, value}`` specs built by create_filter), ``fields`` (a column-to-value equality selection), and ``filter_conditions`` (a mapping of named filter function to its keyword arguments). ``operator`` chooses how the ``filter`` conditions are combined \u2014 ``&`` (AND, default) or ``|`` (OR). All inputs are optional and may be used together.",
6
+ "attributes": [
7
+ {
8
+ "name": "fields",
9
+ "type": "dict",
10
+ "default": {},
11
+ "required": false,
12
+ "description": "Column-to-value equality selection: keep only rows where each column equals the given value (a list value matches any of its entries)."
13
+ },
14
+ {
15
+ "name": "operator",
16
+ "type": "str",
17
+ "default": "&",
18
+ "required": false,
19
+ "description": "Logical operator joining the ``filter`` conditions \u2014 ``&`` (AND, default) or ``|`` (OR)."
20
+ },
21
+ {
22
+ "name": "conditions",
23
+ "type": "list",
24
+ "default": null,
25
+ "required": false,
26
+ "description": "List of filter conditions in create_filter format (``{column, expression, value}``). Optional; combinable with ``filter`` and ``filter_conditions``."
27
+ },
28
+ {
29
+ "name": "filter",
30
+ "type": "list",
31
+ "default": [],
32
+ "required": false,
33
+ "description": "List of filter specs (same ``{column, expression, value}`` format as ``conditions``) passed to create_filter; the resulting masks are joined with ``operator``."
34
+ },
35
+ {
36
+ "name": "filter_conditions",
37
+ "type": "dict",
38
+ "default": {},
39
+ "required": false,
40
+ "description": "Mapping of named filter function (from querysource.types.dt.filters) to its keyword arguments, applied in order before the other filters."
41
+ }
42
+ ],
43
+ "json_schema": {
44
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
45
+ "title": "Filter",
46
+ "type": "object",
47
+ "properties": {
48
+ "fields": {
49
+ "type": "object",
50
+ "description": "Column equality filter \u2014 {column: value | [values]}.",
51
+ "additionalProperties": {
52
+ "description": "Value (or list of values, OR-combined) the column must equal."
53
+ },
54
+ "default": {}
55
+ },
56
+ "operator": {
57
+ "type": "string",
58
+ "enum": [
59
+ "&",
60
+ "|"
61
+ ],
62
+ "description": "Logical operator joining the ``filter`` conditions \u2014 ``&`` (AND, default) or ``|`` (OR).",
63
+ "default": "&"
64
+ },
65
+ "conditions": {
66
+ "type": "array",
67
+ "description": "Filter conditions (create_filter format).",
68
+ "items": {
69
+ "$ref": "#/$defs/filterCondition"
70
+ }
71
+ },
72
+ "filter": {
73
+ "type": "array",
74
+ "description": "Filter specs (create_filter format).",
75
+ "items": {
76
+ "$ref": "#/$defs/filterCondition"
77
+ },
78
+ "default": []
79
+ },
80
+ "filter_conditions": {
81
+ "type": "object",
82
+ "description": "Named filter functions and their keyword arguments.",
83
+ "propertyNames": {
84
+ "$ref": "#/$defs/filterFunc"
85
+ },
86
+ "additionalProperties": {
87
+ "type": "object",
88
+ "description": "Keyword arguments forwarded to the filter function."
89
+ },
90
+ "default": {}
91
+ }
92
+ },
93
+ "additionalProperties": true,
94
+ "description": "Reduce a DataFrame to the rows satisfying the given conditions / functions / field selections (SQL WHERE-like).",
95
+ "$defs": {
96
+ "filterExpression": {
97
+ "type": "string",
98
+ "description": "Comparison or text/null operator applied to a column. ``expression`` may also be a list to chain operators (create_filter_chain).",
99
+ "enum": [
100
+ "==",
101
+ "!=",
102
+ ">",
103
+ "<",
104
+ ">=",
105
+ "<=",
106
+ "gt",
107
+ "lt",
108
+ "contains",
109
+ "not_contains",
110
+ "startswith",
111
+ "not_startswith",
112
+ "endswith",
113
+ "not_endswith",
114
+ "regex",
115
+ "not_regex",
116
+ "fullmatch",
117
+ "is_null",
118
+ "not_null",
119
+ "is_empty",
120
+ "func",
121
+ "function"
122
+ ]
123
+ },
124
+ "filterCondition": {
125
+ "type": "object",
126
+ "description": "A single create_filter condition.",
127
+ "properties": {
128
+ "column": {
129
+ "type": "string",
130
+ "description": "Column to test (must exist in the DataFrame)."
131
+ },
132
+ "expression": {
133
+ "default": "==",
134
+ "description": "Comparison operator, or a list of operators to chain. Defaults to ``==``.",
135
+ "oneOf": [
136
+ {
137
+ "$ref": "#/$defs/filterExpression"
138
+ },
139
+ {
140
+ "type": "array",
141
+ "items": {
142
+ "$ref": "#/$defs/filterExpression"
143
+ }
144
+ }
145
+ ]
146
+ },
147
+ "value": {
148
+ "description": "Value to compare against \u2014 a scalar, ``{\"$column\": \"other_col\"}`` for column-to-column comparison, or a function name when ``expression`` is ``func``/``function``. Omitted for ``is_null``/``not_null``/``is_empty``."
149
+ }
150
+ },
151
+ "required": [
152
+ "column"
153
+ ],
154
+ "additionalProperties": true
155
+ },
156
+ "filterFunc": {
157
+ "type": "string",
158
+ "description": "Named filter function from querysource.types.dt.filters.",
159
+ "enum": [
160
+ "drop_columns",
161
+ "drop_rows",
162
+ "drop_duplicates",
163
+ "clean_empty",
164
+ "suppress",
165
+ "fill_na",
166
+ "fill_nulls",
167
+ "drop_na"
168
+ ]
169
+ }
170
+ }
171
+ },
172
+ "example": "{\n \"Filter\": {\n \"conditions\": [\n {\"column\": \"status\", \"expression\": \"==\", \"value\": \"active\"},\n {\"column\": \"revenue\", \"expression\": \">\", \"value\": 1000}\n ],\n \"operator\": \"&\"\n }\n}",
173
+ "icon": "filter"
174
+ }
@@ -0,0 +1,38 @@
1
+ {
2
+ "name": "FilterCols",
3
+ "category": "Transformations",
4
+ "description": "Drop columns matching a predefined data-quality predicate (filters by content, not by column name).",
5
+ "usage": "Set ``expression`` to one predefined predicate: ``all_null`` (drop columns entirely NaN/None), ``all_empty`` (entirely NaN/None/empty-string), or ``constant`` (all non-null values identical; all-null columns are left to ``all_null``).",
6
+ "attributes": [
7
+ {
8
+ "name": "expression",
9
+ "type": "str",
10
+ "default": null,
11
+ "required": true,
12
+ "description": "Predefined data-quality predicate selecting which columns to drop."
13
+ }
14
+ ],
15
+ "json_schema": {
16
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
17
+ "title": "FilterCols",
18
+ "type": "object",
19
+ "properties": {
20
+ "expression": {
21
+ "type": "string",
22
+ "description": "Data-quality predicate.",
23
+ "enum": [
24
+ "all_empty",
25
+ "all_null",
26
+ "constant"
27
+ ]
28
+ }
29
+ },
30
+ "required": [
31
+ "expression"
32
+ ],
33
+ "additionalProperties": true,
34
+ "description": "Drop columns by data content. ``expression`` is required."
35
+ },
36
+ "example": "{\"Transform\": [{\"FilterCols\": {\"expression\": \"all_null\"}}]}",
37
+ "icon": "shuffle"
38
+ }
@@ -0,0 +1,184 @@
1
+ {
2
+ "name": "Forecast",
3
+ "category": "Transformations",
4
+ "description": "Generate time-series forecasts (ARIMA, SARIMA, or Exponential Smoothing), fitting a model to the values in the target column(s) and appending ``steps`` future predictions to the result.",
5
+ "usage": "Set ``index_column`` (the datetime index), the target series via ``columns`` (list) or ``value_column`` (single column), and ``model``. ``steps`` controls how many future periods to predict and ``frequency`` their spacing. ARIMA/SARIMA use the ``order`` (p,d,q); SARIMA and Exponential require ``by_group`` to forecast each group separately.",
6
+ "attributes": [
7
+ {
8
+ "name": "steps",
9
+ "type": "int",
10
+ "default": 6,
11
+ "required": false,
12
+ "description": "Number of future periods to forecast. Default ``6``."
13
+ },
14
+ {
15
+ "name": "frequency",
16
+ "type": "str",
17
+ "default": "ME",
18
+ "required": false,
19
+ "description": "Pandas offset alias for the spacing of forecasted periods \u2014 e.g. ``D`` (daily), ``W`` (weekly), ``MS`` (month-start), ``ME`` (month-end, default), ``QE`` (quarter-end), ``YE`` (year-end), ``h`` (hourly). Drives the ARIMA forecast date range; Exponential always resamples monthly (``MS``) and SARIMA works in monthly periods."
20
+ },
21
+ {
22
+ "name": "model_args",
23
+ "type": "dict",
24
+ "default": {},
25
+ "required": false,
26
+ "description": "Extra keyword arguments forwarded to the model (currently used by ``Exponential``, e.g. ``alpha``)."
27
+ },
28
+ {
29
+ "name": "reset_index",
30
+ "type": "bool",
31
+ "default": true,
32
+ "required": false,
33
+ "description": "If ``True`` (default), reset the result index after forecasting."
34
+ },
35
+ {
36
+ "name": "order",
37
+ "type": "list",
38
+ "default": [
39
+ 1,
40
+ 1,
41
+ 1
42
+ ],
43
+ "required": false,
44
+ "description": "ARIMA/SARIMA ``(p, d, q)`` order \u2014 autoregressive, differencing, and moving-average terms. Default ``[1, 1, 1]``."
45
+ },
46
+ {
47
+ "name": "index_column",
48
+ "type": "str",
49
+ "default": null,
50
+ "required": true,
51
+ "description": "Name of the datetime column used as the time-series index."
52
+ },
53
+ {
54
+ "name": "columns",
55
+ "type": "list",
56
+ "default": null,
57
+ "required": false,
58
+ "description": "Column(s) to forecast. Each produces its own predictions. Either this or ``value_column`` is required."
59
+ },
60
+ {
61
+ "name": "value_column",
62
+ "type": "str",
63
+ "default": null,
64
+ "required": false,
65
+ "description": "Single-column alias for ``columns`` (promoted to a one-element list when ``columns`` is not provided)."
66
+ },
67
+ {
68
+ "name": "model",
69
+ "type": "str",
70
+ "default": null,
71
+ "required": true,
72
+ "description": "Forecast model. ARIMA = non-seasonal AutoRegressive Integrated Moving Average (per-column, no grouping). SARIMA = Seasonal ARIMA (SARIMAX with a monthly seasonal order (1,1,1,12)); requires ``by_group``. Exponential = Holt-Winters Exponential Smoothing (additive trend + additive seasonal, damped; resamples monthly, needs >= 2x ``steps`` points per series); requires ``by_group``."
73
+ },
74
+ {
75
+ "name": "by_group",
76
+ "type": "str",
77
+ "default": null,
78
+ "required": false,
79
+ "description": "Column to group rows by, forecasting each group independently. Required for ``SARIMA`` and ``Exponential``; ignored by ``ARIMA``."
80
+ }
81
+ ],
82
+ "json_schema": {
83
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
84
+ "title": "Forecast",
85
+ "type": "object",
86
+ "properties": {
87
+ "steps": {
88
+ "type": "integer",
89
+ "description": "Number of future periods to forecast. Default ``6``.",
90
+ "default": 6
91
+ },
92
+ "frequency": {
93
+ "type": "string",
94
+ "description": "Pandas offset alias for the spacing of forecasted periods \u2014 e.g. ``D`` (daily), ``W`` (weekly), ``MS`` (month-start), ``ME`` (month-end, default), ``QE`` (quarter-end), ``YE`` (year-end), ``h`` (hourly). Drives the ARIMA forecast date range; Exponential always resamples monthly (``MS``) and SARIMA works in monthly periods.",
95
+ "default": "ME"
96
+ },
97
+ "model_args": {
98
+ "type": "object",
99
+ "description": "Extra keyword arguments forwarded to the model (currently used by ``Exponential``, e.g. ``alpha``).",
100
+ "default": {}
101
+ },
102
+ "reset_index": {
103
+ "type": "boolean",
104
+ "description": "If ``True`` (default), reset the result index after forecasting.",
105
+ "default": true
106
+ },
107
+ "order": {
108
+ "type": "array",
109
+ "items": {
110
+ "type": "integer"
111
+ },
112
+ "minItems": 3,
113
+ "maxItems": 3,
114
+ "description": "ARIMA (p, d, q) order.",
115
+ "default": [
116
+ 1,
117
+ 1,
118
+ 1
119
+ ]
120
+ },
121
+ "index_column": {
122
+ "type": "string",
123
+ "description": "Name of the datetime column used as the time-series index."
124
+ },
125
+ "columns": {
126
+ "$ref": "#/$defs/columnRef",
127
+ "description": "Numeric column(s) to forecast."
128
+ },
129
+ "value_column": {
130
+ "type": "string",
131
+ "description": "Single-column alias for ``columns`` (promoted to a one-element list when ``columns`` is not provided)."
132
+ },
133
+ "model": {
134
+ "type": "string",
135
+ "description": "Forecast model name.",
136
+ "enum": [
137
+ "ARIMA",
138
+ "SARIMA",
139
+ "Exponential"
140
+ ]
141
+ },
142
+ "by_group": {
143
+ "type": "string",
144
+ "description": "Column to group rows by, forecasting each group independently. Required for ``SARIMA`` and ``Exponential``; ignored by ``ARIMA``."
145
+ }
146
+ },
147
+ "required": [
148
+ "index_column",
149
+ "model"
150
+ ],
151
+ "anyOf": [
152
+ {
153
+ "required": [
154
+ "columns"
155
+ ]
156
+ },
157
+ {
158
+ "required": [
159
+ "value_column"
160
+ ]
161
+ }
162
+ ],
163
+ "additionalProperties": true,
164
+ "description": "Append time-series forecasts to a DataFrame. ``index_column`` and ``model`` are required, plus one of ``columns`` / ``value_column``.",
165
+ "$defs": {
166
+ "columnRef": {
167
+ "description": "A single column name or a list of column names.",
168
+ "oneOf": [
169
+ {
170
+ "type": "string"
171
+ },
172
+ {
173
+ "type": "array",
174
+ "items": {
175
+ "type": "string"
176
+ }
177
+ }
178
+ ]
179
+ }
180
+ }
181
+ },
182
+ "example": "{\n \"Transform\": [\n {\n \"Forecast\": {\n \"index_column\": \"date\",\n \"value_column\": \"revenue\",\n \"model\": \"ARIMA\",\n \"steps\": 12,\n \"frequency\": \"ME\"\n }\n }\n ]\n}",
183
+ "icon": "shuffle"
184
+ }
@@ -0,0 +1,82 @@
1
+ {
2
+ "name": "GoogleMaps",
3
+ "category": "Transformations",
4
+ "description": "Enrich a DataFrame with Google Maps route geometry, distance, and travel-time data (calls the navigator Google Maps Route API per row).",
5
+ "usage": "Operates on rows that contain an ``origin`` and a ``locations`` list (each location with latitude/longitude/location_name/store_id). Locations are sorted by ``timestamp_key`` and a waypoint route (plus an optimal route) is computed, adding route/distance/duration columns (and ``opt_*`` variants).",
6
+ "attributes": [
7
+ {
8
+ "name": "zoom",
9
+ "type": "int",
10
+ "default": 10,
11
+ "required": false,
12
+ "description": "Map zoom level for any embedded map output. Default ``10``."
13
+ },
14
+ {
15
+ "name": "map_scale",
16
+ "type": "int",
17
+ "default": 2,
18
+ "required": false,
19
+ "description": "Scale factor for map output (1 or 2). Default ``2``."
20
+ },
21
+ {
22
+ "name": "timestamp_key",
23
+ "type": "str",
24
+ "default": "timestamp",
25
+ "required": false,
26
+ "description": "Column inside each ``locations`` entry used to sort stops by departure time. Default ``timestamp``."
27
+ },
28
+ {
29
+ "name": "departure_time",
30
+ "type": "str",
31
+ "default": null,
32
+ "required": false,
33
+ "description": "Fixed departure time (ISO string) used when a row has no per-row ``departure_time``. Default ``None``."
34
+ },
35
+ {
36
+ "name": "type",
37
+ "type": "str",
38
+ "default": "get_route",
39
+ "required": false,
40
+ "description": "Route method (navigator ``Route``) to dispatch: ``get_route`` (origin\u2192destination route) or ``waypoint_route`` (multi-stop route). An optimal-route pass is also computed and added as ``opt_*`` columns."
41
+ }
42
+ ],
43
+ "json_schema": {
44
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
45
+ "title": "GoogleMaps",
46
+ "type": "object",
47
+ "properties": {
48
+ "zoom": {
49
+ "type": "integer",
50
+ "description": "Map zoom level for any embedded map output. Default ``10``.",
51
+ "default": 10
52
+ },
53
+ "map_scale": {
54
+ "type": "integer",
55
+ "description": "Scale factor for map output (1 or 2). Default ``2``.",
56
+ "default": 2
57
+ },
58
+ "timestamp_key": {
59
+ "type": "string",
60
+ "description": "Column inside each ``locations`` entry used to sort stops by departure time. Default ``timestamp``.",
61
+ "default": "timestamp"
62
+ },
63
+ "departure_time": {
64
+ "type": "string",
65
+ "description": "Fixed departure time (ISO string) used when a row has no per-row ``departure_time``. Default ``None``."
66
+ },
67
+ "type": {
68
+ "type": "string",
69
+ "description": "Route method to dispatch.",
70
+ "default": "get_route",
71
+ "enum": [
72
+ "get_route",
73
+ "waypoint_route"
74
+ ]
75
+ }
76
+ },
77
+ "additionalProperties": true,
78
+ "description": "Add Google Maps route/travel-time columns to a DataFrame."
79
+ },
80
+ "example": "{\n \"Transform\": [\n {\n \"GoogleMaps\": {\n \"zoom\": 12,\n \"timestamp_key\": \"departure_time\",\n \"type\": \"get_route\"\n }\n }\n ]\n}",
81
+ "icon": "shuffle"
82
+ }