Skip to main content

ingestr is a command-line application that ingests data from various sources and stores them in any database.

Project description

Copy data from any source to any destination without any code


ingestr is a command-line app that allows you to ingest data from any source into any destination using simple command-line flags, no code necessary.

  • โœจ copy data from your database into any destination
  • โž• incremental loading: append, merge or delete+insert
  • ๐Ÿ single-command installation

ingestr takes away the complexity of managing any backend or writing any code for ingesting data, simply run the command and watch the data land on its destination.

MongoDB to Postgres benchmark

Installation

You can install ingestr using the install script:

curl -LsSf https://getbruin.com/install/ingestr | sh

Alternatively, you can install it with pip:

pip install ingestr

Quickstart

ingestr ingest \
    --source-uri 'postgresql://admin:admin@localhost:8837/web?sslmode=disable' \
    --source-table 'public.some_data' \
    --dest-uri 'bigquery://<your-project-name>?credentials_path=/path/to/service/account.json' \
    --dest-table 'ingestr.some_data'

That's it.

This command:

  • gets the table public.some_data from the Postgres instance.
  • uploads this data to your BigQuery warehouse under the schema ingestr and table some_data.

Documentation

You can see the full documentation here.

Community

Join our Slack community here.

Contributing

Pull requests are welcome. However, please open an issue first to discuss what you would like to change. We maybe able to offer you help and feedback regarding any changes you would like to make.

[!NOTE] After cloning ingestr make sure to run make setup to install githooks.

Supported sources & destinations

Source Destination
Databases
AWS Athena โœ… โœ…
AWS Redshift โœ… โœ…
Cassandra โœ… โœ…
ClickHouse โœ… โœ…
Couchbase โœ… -
CrateDB โœ… โœ…
Databricks โœ… โœ…
DuckDB โœ… โœ…
DynamoDB โœ… โœ…
Elasticsearch โœ… โœ…
Google BigQuery โœ… โœ…
GCP Spanner โœ… -
IBM Db2 โœ… -
InfluxDB โœ… -
Kafka โœ… -
Local CSV file โœ… โœ…
Microsoft Fabric โœ… โœ…
Microsoft OneLake - โœ…
Microsoft SQL Server โœ… โœ…
MongoDB โœ… โœ…
MotherDuck โœ… โœ…
MySQL โœ… โœ…
Oracle โœ… -
Postgres โœ… โœ…
RabbitMQ โœ… -
SAP Hana โœ… -
Snowflake โœ… โœ…
Socrata โœ… -
SQLite โœ… โœ…
Synapse - โœ…
Trino โœ… โœ…
Platforms
Adjust โœ… -
Airtable โœ… -
Allium โœ… -
Amazon Kinesis โœ… -
Anthropic โœ… -
AppsFlyer โœ… -
Apple Ads โœ… -
Apple App Store โœ… -
Applovin โœ… -
Applovin Max โœ… -
Asana โœ… -
Attio โœ… -
Azure Data Lake Storage Gen2 โœ… โœ…
Bruin โœ… -
Chess.com โœ… -
ClickUp โœ… -
Cursor โœ… -
Docebo โœ… -
Dune โœ… -
Facebook Ads โœ… -
Fireflies โœ… -
Fluxx โœ… -
Frankfurter โœ… -
Freshdesk โœ… -
FundraiseUp โœ… -
G2 โœ… -
GitHub โœ… -
Google Ads โœ… -
Google Analytics โœ… -
Google Cloud Storage (GCS) โœ… โœ…
Google Sheets โœ… -
Gorgias โœ… -
Granola โœ… -
Hostaway โœ… -
HubSpot โœ… -
Indeed โœ… -
Intercom โœ… -
Internet Society Pulse โœ… -
Jira โœ… -
JobTread โœ… -
Klaviyo โœ… -
Linear โœ… -
LinkedIn Ads โœ… -
Mailchimp โœ… -
Mixpanel โœ… -
Monday โœ… -
Notion โœ… -
Personio โœ… -
PhantomBuster โœ… -
Pinterest โœ… -
Pipedrive โœ… -
Plus Vibe AI โœ… -
PostHog โœ… -
Primer โœ… -
QuickBooks โœ… -
Reddit Ads โœ… -
RevenueCat โœ… -
S3 โœ… โœ…
Salesforce โœ… -
SFTP โœ… -
Shopify โœ… -
Slack โœ… -
Smartsheet โœ… -
Snapchat Ads โœ… -
Solidgate โœ… -
Stripe โœ… -
SurveyMonkey โœ… -
TikTok Ads โœ… -
Trustpilot โœ… -
Wise โœ… -
Zendesk โœ… -
Zoom โœ… -

Feel free to create an issue if you'd like to see support for another source or destination.

License

ingestr is source-available under the Functional Source License 1.1, with Apache 2.0 as the future license. You can use ingestr freely for internal production use, development, testing, education, research, and professional services. You cannot use ingestr to offer a competing commercial ingestion, ELT, connector, or managed data pipeline product/service.

Each version becomes Apache 2.0 two years after release.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

ingestr-1.0.25-py2.py3-none-win_amd64.whl (59.6 MB view details)

Uploaded Python 2Python 3Windows x86-64

ingestr-1.0.25-py2.py3-none-manylinux2014_x86_64.whl (58.0 MB view details)

Uploaded Python 2Python 3

ingestr-1.0.25-py2.py3-none-manylinux2014_aarch64.whl (51.8 MB view details)

Uploaded Python 2Python 3

ingestr-1.0.25-py2.py3-none-macosx_11_0_arm64.whl (53.5 MB view details)

Uploaded Python 2Python 3macOS 11.0+ ARM64

ingestr-1.0.25-py2.py3-none-macosx_10_15_x86_64.whl (58.3 MB view details)

Uploaded Python 2Python 3macOS 10.15+ x86-64

File details

Details for the file ingestr-1.0.25-py2.py3-none-win_amd64.whl.

File metadata

  • Download URL: ingestr-1.0.25-py2.py3-none-win_amd64.whl
  • Upload date:
  • Size: 59.6 MB
  • Tags: Python 2, Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for ingestr-1.0.25-py2.py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 fbddf75a3eef1fe39228390d4af417e693e67929e0b9f7c6a4f5b0a2e4f6f7ed
MD5 c85f12b12f5ee135c3511a83b4bd87c2
BLAKE2b-256 fe2ac8c7e2e85109d5d37ffb0cd9632850e2cf3f793966b5a115b8df15a12ac8

See more details on using hashes here.

File details

Details for the file ingestr-1.0.25-py2.py3-none-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for ingestr-1.0.25-py2.py3-none-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 e8a39ae1bfa299754eda70eb176ca27f8c61ed7da51a088f7e86a79d775c6438
MD5 61daefe357f47c9d8de294d708f2387e
BLAKE2b-256 b9cd58e32501aced925f88264143fe1d3a22316b1b111622f1bd1ca3fb22f22e

See more details on using hashes here.

File details

Details for the file ingestr-1.0.25-py2.py3-none-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for ingestr-1.0.25-py2.py3-none-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 82cb5c09d3d2e519587761544b5a77c900abbcf615d3cc05208df8033ad9255d
MD5 42d8df095ae641c44444ebcdf022e513
BLAKE2b-256 eae748f922d8f350ed6ec21a5beaeacfd6d6dcb409fde9f4fef32df6a041dc10

See more details on using hashes here.

File details

Details for the file ingestr-1.0.25-py2.py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for ingestr-1.0.25-py2.py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 f949011039fa6b17b4b091c90d8ea0be436317b082f1c10bbf3cbfc63cf8d12a
MD5 6ab056bb1f79aed0ed6e69df353380f3
BLAKE2b-256 c8a571c321214fc3ecb02791f41a75709bba3223d8a40cf0476f2f33dd5a376c

See more details on using hashes here.

File details

Details for the file ingestr-1.0.25-py2.py3-none-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for ingestr-1.0.25-py2.py3-none-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 d8a634a42fdbe5b9e1164be0804812bd069c0c7a7bf614866aff653c567fcaee
MD5 fc2a6bfd13daee500ea7423d295c20af
BLAKE2b-256 0f246319b2b70596de0c3e8352f6b0d59d4543152637eb0f5cb2d810b140d81c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page