querysource 4.4.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.
- querysource-4.4.2/.pre-commit-config.yaml +21 -0
- {querysource-4.4.0 → querysource-4.4.2}/PKG-INFO +1 -1
- querysource-4.4.2/generated/DropCols.json +109 -0
- querysource-4.4.2/generated/Filter.json +174 -0
- querysource-4.4.2/generated/FilterCols.json +38 -0
- querysource-4.4.2/generated/Forecast.json +184 -0
- querysource-4.4.2/generated/GoogleMaps.json +82 -0
- querysource-4.4.2/generated/GroupBy.json +106 -0
- querysource-4.4.2/generated/Join.json +149 -0
- querysource-4.4.2/generated/Map.json +228 -0
- querysource-4.4.2/generated/Melt.json +93 -0
- querysource-4.4.2/generated/Merge.json +137 -0
- querysource-4.4.2/generated/PluckCols.json +109 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/Query.json +32 -8
- querysource-4.4.2/generated/correlation.json +125 -0
- querysource-4.4.2/generated/crosstab.json +132 -0
- querysource-4.4.2/generated/pivot.json +166 -0
- querysource-4.4.2/generated/tExplode.json +84 -0
- querysource-4.4.2/generated/tOrder.json +99 -0
- {querysource-4.4.0 → querysource-4.4.2}/pyproject.toml +1 -1
- {querysource-4.4.0 → querysource-4.4.2}/querysource/_version.py +3 -3
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/bigquery.c +1241 -1228
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/bigquery.pyx +2 -1
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/_introspect.py +267 -5
- querysource-4.4.2/querysource/queries/multi/operators/GroupBy.catalog.yaml +99 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/GroupBy.py +13 -0
- querysource-4.4.2/querysource/queries/multi/operators/Join.catalog.yaml +151 -0
- querysource-4.4.2/querysource/queries/multi/operators/Melt.catalog.yaml +105 -0
- querysource-4.4.2/querysource/queries/multi/operators/Merge.catalog.yaml +113 -0
- querysource-4.4.2/querysource/queries/multi/operators/filter/Filter.catalog.yaml +169 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/filter/flt.py +28 -3
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/registry.py +23 -23
- querysource-4.4.2/querysource/queries/multi/sources/query.catalog.yaml +111 -0
- querysource-4.4.2/querysource/queries/multi/sources/query.py +86 -0
- querysource-4.4.2/querysource/queries/multi/transformations/DropCols.catalog.yaml +78 -0
- querysource-4.4.2/querysource/queries/multi/transformations/FilterCols.catalog.yaml +43 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/FilterCols.py +10 -0
- querysource-4.4.2/querysource/queries/multi/transformations/Forecast.catalog.yaml +149 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/Forecast.py +15 -1
- querysource-4.4.2/querysource/queries/multi/transformations/Map.catalog.yaml +102 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/Map.py +27 -8
- querysource-4.4.2/querysource/queries/multi/transformations/PluckCols.catalog.yaml +78 -0
- querysource-4.4.2/querysource/queries/multi/transformations/correlation.catalog.yaml +105 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/correlation.py +1 -1
- querysource-4.4.2/querysource/queries/multi/transformations/crosstab.catalog.yaml +113 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/crosstab.py +1 -1
- querysource-4.4.2/querysource/queries/multi/transformations/google/GoogleMaps.catalog.yaml +83 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/google/maps.py +25 -5
- querysource-4.4.2/querysource/queries/multi/transformations/pivot.catalog.yaml +138 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/pivot.py +1 -1
- querysource-4.4.2/querysource/queries/multi/transformations/tExplode.catalog.yaml +81 -0
- querysource-4.4.2/querysource/queries/multi/transformations/tOrder.catalog.yaml +87 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/version.py +1 -1
- {querysource-4.4.0 → querysource-4.4.2}/querysource.egg-info/PKG-INFO +1 -1
- {querysource-4.4.0 → querysource-4.4.2}/querysource.egg-info/SOURCES.txt +28 -1
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/validators.rs +34 -1
- querysource-4.4.2/tests/test_catalog_colcols.py +37 -0
- querysource-4.4.2/tests/test_catalog_correlation.py +30 -0
- querysource-4.4.2/tests/test_catalog_filter.py +84 -0
- querysource-4.4.2/tests/test_catalog_forecast.py +54 -0
- querysource-4.4.2/tests/test_catalog_googlemaps.py +47 -0
- querysource-4.4.2/tests/test_catalog_groupby.py +48 -0
- querysource-4.4.2/tests/test_catalog_map.py +74 -0
- querysource-4.4.2/tests/test_catalog_pivot.py +34 -0
- querysource-4.4.2/tests/test_catalog_remote.py +53 -0
- querysource-4.4.2/tests/test_catalog_texplode.py +28 -0
- querysource-4.4.2/tests/test_catalog_torder.py +29 -0
- querysource-4.4.0/generated/DropCols.json +0 -58
- querysource-4.4.0/generated/Filter.json +0 -54
- querysource-4.4.0/generated/FilterCols.json +0 -28
- querysource-4.4.0/generated/Forecast.json +0 -68
- querysource-4.4.0/generated/GoogleMaps.json +0 -66
- querysource-4.4.0/generated/GroupBy.json +0 -48
- querysource-4.4.0/generated/Join.json +0 -62
- querysource-4.4.0/generated/Map.json +0 -28
- querysource-4.4.0/generated/Melt.json +0 -34
- querysource-4.4.0/generated/Merge.json +0 -58
- querysource-4.4.0/generated/PluckCols.json +0 -58
- querysource-4.4.0/generated/ThreadQuery.json +0 -10
- querysource-4.4.0/generated/correlation.json +0 -34
- querysource-4.4.0/generated/crosstab.json +0 -36
- querysource-4.4.0/generated/pivot.json +0 -60
- querysource-4.4.0/generated/tExplode.json +0 -68
- querysource-4.4.0/generated/tOrder.json +0 -62
- querysource-4.4.0/querysource/queries/multi/sources/query.py +0 -238
- querysource-4.4.0/tests/test_catalog_remote.py +0 -33
- {querysource-4.4.0 → querysource-4.4.2}/.agent/rules/async-programming-expert.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/rules/code-reviewer.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/rules/cython-development.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/rules/prompt-expert.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/rules/python-development.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/rules/rust-development.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/workflows/create-parrot-tool.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/workflows/create-workflow.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/workflows/debug-regressions-with-git-bisect-binary-search.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/workflows/generate-tests.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/workflows/git-new-feature.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/workflows/parrot-mcp-server.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/workflows/release_package.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.agent/workflows/start-flow.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.bumpversion.cfg +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/agents/code-reviewer.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/agents/sdd-autopilot.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/agents/sdd-qa.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/agents/sdd-research.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/agents/sdd-worker.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/pr-review.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-brainstorm.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-codereview.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-done.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-fromjira.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-next.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-proposal.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-spec.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-start.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-status.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-task.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/commands/sdd-tojira.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/aws-cost-optimization.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/code-reviewer.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/cython-development.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/python-development.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/rust-development.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/using-git-worktrees.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/worktree-pr-and-clean.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/worktree-start-feature.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.claude/rules/worktree-status.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.github/dependabot.yml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.github/workflows/codeql-analysis.yml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.github/workflows/release.yml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.isort.cfg +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.jupyter/jupyter_notebook_config.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/.pylintrc +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/CHANGES.rst +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/CODE_OF_CONDUCT.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/CONTRIBUTING.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/INSTALL +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/JOIN_CONDITIONS_FEATURE.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/JOIN_CONDITIONS_SUMMARY.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/LICENSE +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/MANIFEST.in +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/Makefile +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/README.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/app.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/bin/README.md +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/conftest.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/AirtableSource.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/Concat.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/DWHDestination.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/FileSource.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/Info.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/S3Source.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/SharepointSource.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/SmartSheetSource.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/Table.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/TableDestination.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/TableOutput.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/TableOutputAdapter.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/TableSource.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/ToS3.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/ToSharepoint.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/generated/tPandas.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/gunicorn_config.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/mypy.ini +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/nav.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/policies/datasources.yaml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/policies/defaults.yaml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/policies/drivers.yaml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/policies/raw_queries.yaml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/policies/slugs.yaml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/policies/superusers.yaml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/pytest.ini +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/qs-parser/Cargo.lock +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/qs-parser/Cargo.toml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/qs-parser/pyproject.toml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/qs-parser/src/lib.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/qs-parser/src/parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/qs-parser/src/sql.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/__cli__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/auth/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/auth/_resource_types.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/auth/credentials.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/auth/pbac.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/cache/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/cache/backends/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/cache/backends/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/cache/backends/memcache.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/cache/backends/redis.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/cache/base.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/cli/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/cli/generate_docs.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/conf.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/connections.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/arangodb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/athena.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/bigquery.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/cassandra.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/clickhouse.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/cockroachdb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/couchbase.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/couchdb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/countries.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/delta.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/documentdb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/dynamodb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/elastic.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/ga.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/gcalc.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/hazel.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/iceberg.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/influx.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/jdbc.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/jira.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/mariadb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/memcached.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/mongo.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/mysql.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/odbc.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/openweather.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/oracle.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/pg.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/pg_admin.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/postgres.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/py.typed +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/qs.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/redis.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/rest.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/rethink.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/sa.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/salesforce.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/scylladb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/sqlalchemy.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/sqlite.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/sqlserver.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/upc.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/drivers/zipcodeapi.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/handlers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/handlers/datasource.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/handlers/utils.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/datasources/models.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/events/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/exceptions.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/_pagination.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/components.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/executor.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/integrations/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/integrations/airtable.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/log.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/manager.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/multi.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/outputs/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/outputs/tableOutput/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/outputs/tableOutput/postgres.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/outputs/tableOutput/table.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/scheduler.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/service.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/handlers/variables.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/airtable.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/connections.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/credentials.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/databases/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/databases/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/databases/bigquery.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/databases/db.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/databases/mongo.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/databases/rethink.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/http.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/playwright_service.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/queries.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/interfaces/selenium_service.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/libs/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/libs/encoders.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/libs/functions/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/libs/py.typed +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/models.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/destinations/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/destinations/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/destinations/dwh.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/destinations/s3.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/destinations/sharepoint.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/destinations/table.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/arrow.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/dt.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/factory.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/iter.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/modin.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/pandas.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/dt/polars.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/output.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/bigquery.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/documentdb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/mongodb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/mysql.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/postgres.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/rethink.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/sa.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/TableOutput/table.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/tables/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/bokeh.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/clustering.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/csv.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/describe.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/eda.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/excel.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/html.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/json.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/pdf.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/pickle.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/plotly.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/profiling.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/report.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/table.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/tsv.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/txt.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/outputs/writers/xml.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/abstract.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/abstract.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/abstract.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/arangodb.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/arangodb.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/arangodb.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/bigquery.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/cql.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/cql.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/cql.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/deltatbl.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/deltatbl.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/deltatbl.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/elastic.cpp +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/elastic.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/elastic.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/iceberg.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/iceberg.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/iceberg.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/influx.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/influx.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/influx.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/mongo.cpp +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/mongo.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/mongo.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/parser.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/parser.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/parser.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/pgsql.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/pgsql.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/pgsql.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/rethink.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/rethink.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/rethink.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sosql.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sosql.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sosql.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sql.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sql.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sql.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sqlserver.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sqlserver.pxd +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/parsers/sqlserver.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/plugins/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/plugins/importer.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/plugins/sources/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/arangodb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/bigquery.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/cassandra.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/db.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/default.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/deltatbl.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/documentdb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/dummy.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/elastic.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/external.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/http.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/iceberg.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/influx.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/mysql.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/pg.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/py.typed +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/rest.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/rethink.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/salesforce.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/scylladb.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/amazon.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/countries.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/ga.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/geofcc.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/gmaps.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/graphcountries.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/graphql.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/http.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/hubspot.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/openweather.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/parsers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/parsers/amproduct.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/parsers/xpath.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/pokemon.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/populartimes.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/py.typed +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/rest.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/retailnext.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/rssapp.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/salesforce.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/scrapper.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/shoppertrack.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/swop.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/uap.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/upc.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/wm_stores.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/zammad.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sources/zipcodeapi.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sql.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/providers/sqlserver.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/py.typed +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/qs_parsers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/base.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/executor.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/models.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/components/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/components/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/destinations/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/destinations/dwh.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/destinations/s3.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/destinations/sharepoint.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/destinations/table.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/Concat.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/Info.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/Join.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/Melt.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/Merge.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/operators/filter/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/airtable.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/base.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/executors.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/file.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/s3.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/sharepoint.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/smartsheet.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/sources/table.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/DropCols.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/PluckCols.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/abstract.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/google/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/tExplode.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/tOrder.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/multi/transformations/tPandas.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/obj.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/queries/qs.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/scheduler/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/scheduler/jobs.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/scheduler/notifications.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/scheduler/scheduler.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/services.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/template/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/template/parser.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/converters.cpp +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/converters.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/dt/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/dt/filters.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/dt/transforms.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/py.typed +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/typedefs.c +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/typedefs.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/validators.cpp +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/types/validators.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/cache_serialization.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/events.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/fn.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/functions.cpp +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/functions.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/getfunc.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/handlers.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/parseqs.cpp +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/parseqs.pyx +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource/utils/validators.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource.egg-info/dependency_links.txt +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource.egg-info/entry_points.txt +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource.egg-info/not-zip-safe +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource.egg-info/requires.txt +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/querysource.egg-info/top_level.txt +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/run.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/Cargo.lock +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/Cargo.toml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/pyproject.toml +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/arangodb_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/bigquery_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/cql_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/elastic_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/filter_common.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/flux_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/lib.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/mongo_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/mssql_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/parseqs.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/pgsql_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/rethink_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/safe_dict.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/soql_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/rust/src/sql_parser.rs +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/setup.cfg +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/setup.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/static/notebook/bundle.js +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/templates/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/templates/base.html +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/templates/default.html +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/templates/default_table.html +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/templates/fontlist-v330.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/templates/fontlist-v390.json +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/templates/table_charts.html +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/auth/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/auth/test_credentials.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/auth/test_pbac_bootstrap.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/check_concurrent_get_slug.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/conftest.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/datasources/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/datasources/test_datasource_view_pbac.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/datasources/test_driver_factory_session.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/datasources/test_pg_admin_registration.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/datasources/test_pg_params_for.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/handlers/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/handlers/conftest.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/handlers/test_abstract_pbac_helpers.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/handlers/test_airtable_oauth.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/handlers/test_multiquery_pbac_smoke.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/handlers/test_queryexecutor_pbac_smoke.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/handlers/test_querymanager_pagination.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/handlers/test_queryservice_pbac_smoke.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/integration/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/integration/test_pbac_credentials.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/integration/test_pbac_enforcement.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/integration/test_pbac_listing.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/interfaces/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/interfaces/test_airtable_interface.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/multi/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/multi/sources/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/multi/sources/test_airtable_source.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/multi/sources/test_registry.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/perf/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/perf/test_pbac_overhead.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/policies/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/policies/test_default_policies_load.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/scheduler/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/scheduler/test_parse_trigger_shorthands.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/scheduler/test_shorthand_loaders.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/services/__init__.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/services/test_querysource_setup_pbac.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_abstract_multi.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_abstract_refactor.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_api.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_arangodb_parser.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_cli_generate_docs.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_column_filters.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_component_handler.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_component_registry.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_conf_airtable.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_destination_base.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_destination_dwh.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_destination_integration.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_destination_s3.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_destination_sharepoint.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_destination_table.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_destinations_documentation_endpoint.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_elastic_parser.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_eval.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_info_eda.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_info_eda_e2e.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_info_eda_integration.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_join_conditions.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_join_with_column_filter.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_local_executor.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_multi_destinations_subpackage.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_multiqs_column_transforms.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_multiqs_destination_dispatch.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_multiqs_remote_dispatch.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_multiqs_sources_integration.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_queryslug_concurrency.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_querysource_setup_airtable.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_qworker_config.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_remote_executor.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_route_registration.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_rss.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_rust_parsers.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_scheduler_core.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_scheduler_handler_integration.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_scheduler_handler_unit.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_scheduler_integration.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_scheduler_jobs.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_scheduler_multi_routing.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_scheduler_notifications.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_schema_introspectable.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_source_registry.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_source_s3.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_source_sharepoint.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_source_smartsheet.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_source_table.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_sql_parser_combinations.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_texplode.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_thread_file_refactor.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_thread_query_refactor.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_thread_source_base.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_threadquery_executor.py +0 -0
- {querysource-4.4.0 → querysource-4.4.2}/tests/test_zammad_search.py +0 -0
- {querysource-4.4.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]
|
|
@@ -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
|
+
}
|