ingestr 0.2.2__tar.gz → 0.2.3__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of ingestr might be problematic. Click here for more details.

Files changed (63) hide show
  1. {ingestr-0.2.2 → ingestr-0.2.3}/Makefile +1 -1
  2. {ingestr-0.2.2 → ingestr-0.2.3}/PKG-INFO +1 -1
  3. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/destinations.py +17 -5
  4. ingestr-0.2.3/ingestr/src/version.py +1 -0
  5. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/testdata/test_create_replace.db +0 -0
  6. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/testdata/test_delete_insert_with_timerange.db +0 -0
  7. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/testdata/test_delete_insert_without_primary_key.db +0 -0
  8. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/testdata/test_merge_with_primary_key.db +0 -0
  9. ingestr-0.2.2/ingestr/src/version.py +0 -1
  10. {ingestr-0.2.2 → ingestr-0.2.3}/.dockerignore +0 -0
  11. {ingestr-0.2.2 → ingestr-0.2.3}/.github/workflows/deploy-docs.yml +0 -0
  12. {ingestr-0.2.2 → ingestr-0.2.3}/.github/workflows/docker.yml +0 -0
  13. {ingestr-0.2.2 → ingestr-0.2.3}/.gitignore +0 -0
  14. {ingestr-0.2.2 → ingestr-0.2.3}/Dockerfile +0 -0
  15. {ingestr-0.2.2 → ingestr-0.2.3}/LICENSE.md +0 -0
  16. {ingestr-0.2.2 → ingestr-0.2.3}/README.md +0 -0
  17. {ingestr-0.2.2 → ingestr-0.2.3}/docs/.vitepress/config.mjs +0 -0
  18. {ingestr-0.2.2 → ingestr-0.2.3}/docs/.vitepress/theme/custom.css +0 -0
  19. {ingestr-0.2.2 → ingestr-0.2.3}/docs/.vitepress/theme/index.js +0 -0
  20. {ingestr-0.2.2 → ingestr-0.2.3}/docs/commands/example-uris.md +0 -0
  21. {ingestr-0.2.2 → ingestr-0.2.3}/docs/commands/ingest.md +0 -0
  22. {ingestr-0.2.2 → ingestr-0.2.3}/docs/getting-started/core-concepts.md +0 -0
  23. {ingestr-0.2.2 → ingestr-0.2.3}/docs/getting-started/incremental-loading.md +0 -0
  24. {ingestr-0.2.2 → ingestr-0.2.3}/docs/getting-started/quickstart.md +0 -0
  25. {ingestr-0.2.2 → ingestr-0.2.3}/docs/getting-started/telemetry.md +0 -0
  26. {ingestr-0.2.2 → ingestr-0.2.3}/docs/index.md +0 -0
  27. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/bigquery.md +0 -0
  28. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/csv.md +0 -0
  29. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/databricks.md +0 -0
  30. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/duckdb.md +0 -0
  31. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/mongodb.md +0 -0
  32. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/mssql.md +0 -0
  33. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/mysql.md +0 -0
  34. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/oracle.md +0 -0
  35. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/overview.md +0 -0
  36. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/postgres.md +0 -0
  37. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/redshift.md +0 -0
  38. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/snowflake.md +0 -0
  39. {ingestr-0.2.2 → ingestr-0.2.3}/docs/supported-sources/sqlite.md +0 -0
  40. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/main.py +0 -0
  41. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/main_test.py +0 -0
  42. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/destinations_test.py +0 -0
  43. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/factory.py +0 -0
  44. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/factory_test.py +0 -0
  45. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/mongodb/__init__.py +0 -0
  46. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/mongodb/helpers.py +0 -0
  47. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/sources.py +0 -0
  48. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/sources_test.py +0 -0
  49. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/sql_database/__init__.py +0 -0
  50. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/sql_database/helpers.py +0 -0
  51. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/sql_database/schema_types.py +0 -0
  52. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/sql_database/settings.py +0 -0
  53. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/telemetry/event.py +0 -0
  54. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/src/testdata/fakebqcredentials.json +0 -0
  55. {ingestr-0.2.2 → ingestr-0.2.3}/ingestr/testdata/.gitignore +0 -0
  56. {ingestr-0.2.2 → ingestr-0.2.3}/package-lock.json +0 -0
  57. {ingestr-0.2.2 → ingestr-0.2.3}/package.json +0 -0
  58. {ingestr-0.2.2 → ingestr-0.2.3}/pyproject.toml +0 -0
  59. {ingestr-0.2.2 → ingestr-0.2.3}/requirements-dev.txt +0 -0
  60. {ingestr-0.2.2 → ingestr-0.2.3}/requirements.txt +0 -0
  61. {ingestr-0.2.2 → ingestr-0.2.3}/resources/demo.gif +0 -0
  62. {ingestr-0.2.2 → ingestr-0.2.3}/resources/demo.tape +0 -0
  63. {ingestr-0.2.2 → ingestr-0.2.3}/resources/ingestr.svg +0 -0
@@ -18,7 +18,7 @@ test: venv
18
18
  . venv/bin/activate; $(MAKE) test-ci
19
19
 
20
20
  test-specific: venv
21
- . venv/bin/activate; pytest -rP -vv --tb=short --cov=ingestr --no-cov-on-fail --capture=no -k $(test)
21
+ . venv/bin/activate; pytest -rP -vv --tb=short --capture=no -k $(test)
22
22
 
23
23
  lint-ci:
24
24
  ruff ingestr --fix && ruff format ingestr
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: ingestr
3
- Version: 0.2.2
3
+ Version: 0.2.3
4
4
  Summary: ingestr is a command-line application that ingests data from various sources and stores them in any database.
5
5
  Project-URL: Homepage, https://github.com/bruin-data/ingestr
6
6
  Project-URL: Issues, https://github.com/bruin-data/ingestr/issues
@@ -1,3 +1,4 @@
1
+ import base64
1
2
  import csv
2
3
  import gzip
3
4
  import json
@@ -32,8 +33,11 @@ class BigQueryDestination:
32
33
  source_params = parse_qs(source_fields.query)
33
34
 
34
35
  cred_path = source_params.get("credentials_path")
35
- if not cred_path:
36
- raise ValueError("Credentials path is required")
36
+ credentials_base64 = source_params.get("credentials_base64")
37
+ if not cred_path and not credentials_base64:
38
+ raise ValueError(
39
+ "credentials_path or credentials_base64 is required to connect BigQuery"
40
+ )
37
41
 
38
42
  location = None
39
43
  if source_params.get("location"):
@@ -42,11 +46,19 @@ class BigQueryDestination:
42
46
  raise ValueError("Only one location is allowed")
43
47
  location = loc_params[0]
44
48
 
45
- with open(cred_path[0], "r") as f:
46
- credentials = json.load(f)
49
+ credentials = {}
50
+ if cred_path:
51
+ with open(cred_path[0], "r") as f:
52
+ credentials = json.load(f)
53
+ elif credentials_base64:
54
+ credentials = json.loads(
55
+ base64.b64decode(credentials_base64[0]).decode("utf-8")
56
+ )
47
57
 
48
58
  return dlt.destinations.bigquery(
49
- credentials=credentials, location=location, **kwargs
59
+ credentials=credentials, # type: ignore
60
+ location=location,
61
+ **kwargs,
50
62
  )
51
63
 
52
64
  def dlt_run_params(self, uri: str, table: str, **kwargs) -> dict:
@@ -0,0 +1 @@
1
+ __version__ = "0.2.3"
@@ -1 +0,0 @@
1
- __version__ = "0.2.2"
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes