# Nodestream
<picture >
<source media="(prefers-color-scheme: dark)" srcset="./docs/img/NodeSteamLogo_Small_Light.png">
<img alt="Nodestream Logo" src="./docs/img/NodeSteamLogo_Small_Dark.png" width="300" align="right">
</picture>
> A Declarative framework for Building, Maintaining, and Analyzing Graph Data 🚀
[![Continuous Integration](https://github.com/nodestream-proj/nodestream/actions/workflows/ci.yaml/badge.svg)](https://github.com/nodestream-proj/nodestream/actions/workflows/ci.yaml)
[![codecov](https://codecov.io/gh/nodestream-proj/nodestream/branch/main/graph/badge.svg?token=HAPEVKQ6OQ)](https://codecov.io/gh/nodestream-proj/nodestream)
[![ApacheV2 License](https://img.shields.io/badge/License-Apache%202.0-yellow.svg)](https://opensource.org/license/apache-2-0/)
<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->
[![All Contributors](https://img.shields.io/badge/all_contributors-11-orange.svg?style=flat-square)](#contributors-)
<!-- ALL-CONTRIBUTORS-BADGE:END -->
**Nodestream allows you to work with graphs declaratively.** With nodestream, you unlock a bounty of features purpose built for working with graphs.
Semantically model your graph and map labels and properties directly to your data.
Better yet, you are not locked into your choices.
Nodestream works with you as you evolve your application by providing migration utilities to change your data schema.
Nodestream even decouples you from the underyling database technology so you can even change databases.
#### Highlights
- Connect to data sources like [Kafka](https://nodestream-proj.github.io/docs/docs/reference/extractors/#streamextractor), [files](https://nodestream-proj.github.io/docs/docs/reference/extractors/#unifiedfileextractor), [apis](https://nodestream-proj.github.io/docs/docs/reference/extractors/#simpleapiextractor), and [more](https://nodestream-proj.github.io/docs/docs/reference/extractors/)!
- Evolve your application over time with database migrations ([Docs](https://nodestream-proj.github.io/docs/docs/tutorials-intermediate/working-with-migrations/))
- Use your favorite Graph Database to fit any tech stack ([Docs](https://nodestream-proj.github.io/docs/docs/category/database-support/))
- Clean up your own data with TTLs ([Docs](https://nodestream-proj.github.io/docs/docs/tutorials-intermediate/removing-data/#implementing-a-ttl-pipeline))
- Infinite Customizability Since Nearly Everything is Pluggable!
> [Website](https://nodestream-proj.github.io/docs/) • [Blog](https://nodestream-proj.github.io/docs/blog/) • [Discussions](https://github.com/orgs/nodestream-proj/discussions) • [Contributing](#contributing) • [Contributing Developer Guides](https://nodestream-proj.github.io/docs/docs/category/developer-reference/) • [Talks from Maintainers](https://www.youtube.com/watch?v=2F-xx4LcTng&list=PLUiAbWRQecSOorv_V6TzfUBoIZyf-6r6R&pp=gAQBiAQB)
## Features
Nodestream has a pleasant CLI interface to get new projects up and running fast.
![Demo](https://raw.githubusercontent.com/nodestream-proj/nodestream/e94d0faa024c0f8da1e83a4ff6d83746504d197e/docs/img/demo.gif)
Not a fan of the defaults? You can change out databases very easily
![Using Another Database](https://nodestream-proj.github.io/docs/assets/images/neptune-2c1c78b173e824fc1e824f54287e467f.gif)
Then you can start to model your data and nodestream will evolve your database for you. No more messing with constraints or writing database queries.
![Running Migrations](https://nodestream-proj.github.io/docs/assets/images/migrations-1ede1ab3d5438cdca24d66cfa6d66231.gif)
## Getting Started
Conviced? Install nodestream with `pip` to get started.
```bash
pip install nodestream
nodestream new --database neo4j my_project && cd my_project
nodestream run sample -v
```
We highly recommend following our tutorials [here](https://nodestream-proj.github.io/docs/docs/category/tutorial---basics/)
## Packages
Nodestream is built on a Highly Pluggable and Modular Architecture. Thus... we have a lot of packages to keep track of.
| Package | Description | Version |
|------------------------------ |------------------------------------------------------------------------------- |-------------------------------------------------------------------------------------------------------------------------------- |
| `nodestream` | The core library. Declarative ingestion. | ![PyPI Version](https://badge.fury.io/py/nodestream.svg) |
| `nodestream-plugin-neo4j` | Neo4j database connector. | ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-neo4j.svg) |
| `nodestream-plugin-neptune` | AWS Neptune database connector. | ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-neptune.svg) |
| `nodestream-plugin-dotenv` | Adds DotEnv integration. | ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-dotenv.svg) |
| `nodestream-plugin-pedantic` | A series of lints to enforce reasonable naming standards, etc. | ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-pedantic.svg) |
| `nodestream-plugin-shell` | An integration with nodestream to run shell commands. | ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-shell.svg) |
| `nodestream-plugin-sbom` | Import SBOM files in CycloneDX and SPDX into an opinionated graph data model. | ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-sbom.svg) |
| `nodestream-plugin-akamai` | Parse Akamai properties, redirect configs, and much more and ingests them. | ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-akamai.svg) |
| `nodestream-plugin-k8s` | In incubation. A plugin that orchestrates Nodestream on k8s. | ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-k8s.svg) |
## Contributors
Nodestream is a community project. We welcome all contributions.
Be sure to checkout or [Contributing Docs](https://nodestream-proj.github.io/docs/docs/category/developer-reference/) and our [Code of Conduct](./CODE_OF_CONDUCT.md) before contributing.
<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->
<!-- prettier-ignore-start -->
<!-- markdownlint-disable -->
<table>
<tbody>
<tr>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/zprobst"><img src="https://avatars.githubusercontent.com/u/22159145?v=4?s=100" width="100px;" alt="Zach Probst"/><br /><sub><b>Zach Probst</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=zprobst" title="Code">💻</a> <a href="https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Azprobst" title="Reviewed Pull Requests">👀</a> <a href="#maintenance-zprobst" title="Maintenance">🚧</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/ccloes"><img src="https://avatars.githubusercontent.com/u/1000538?v=4?s=100" width="100px;" alt="Chad Cloes"/><br /><sub><b>Chad Cloes</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=ccloes" title="Code">💻</a> <a href="https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Accloes" title="Reviewed Pull Requests">👀</a> <a href="#maintenance-ccloes" title="Maintenance">🚧</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/angelosantos4"><img src="https://avatars.githubusercontent.com/u/142852840?v=4?s=100" width="100px;" alt="asantos4"/><br /><sub><b>asantos4</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=angelosantos4" title="Code">💻</a> <a href="https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Aangelosantos4" title="Reviewed Pull Requests">👀</a> <a href="#maintenance-angelosantos4" title="Maintenance">🚧</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/grantleehoffman"><img src="https://avatars.githubusercontent.com/u/603848?v=4?s=100" width="100px;" alt="Grant Hoffman"/><br /><sub><b>Grant Hoffman</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=grantleehoffman" title="Code">💻</a> <a href="https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Agrantleehoffman" title="Reviewed Pull Requests">👀</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/khneal"><img src="https://avatars.githubusercontent.com/u/40273388?v=4?s=100" width="100px;" alt="khneal"/><br /><sub><b>khneal</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=khneal" title="Code">💻</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/orozen"><img src="https://avatars.githubusercontent.com/u/62594754?v=4?s=100" width="100px;" alt="orozen"/><br /><sub><b>orozen</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=orozen" title="Code">💻</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://sites.google.com/view/ai4allrobotics"><img src="https://avatars.githubusercontent.com/u/66497192?v=4?s=100" width="100px;" alt="Sophia Don Tranho"/><br /><sub><b>Sophia Don Tranho</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=sophiadt" title="Code">💻</a></td>
</tr>
<tr>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/bechbd"><img src="https://avatars.githubusercontent.com/u/6898505?v=4?s=100" width="100px;" alt="bechbd"/><br /><sub><b>bechbd</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=bechbd" title="Code">💻</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/yasonk"><img src="https://avatars.githubusercontent.com/u/6750414?v=4?s=100" width="100px;" alt="yasonk"/><br /><sub><b>yasonk</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=yasonk" title="Code">💻</a> <a href="https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Ayasonk" title="Reviewed Pull Requests">👀</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/stuartio"><img src="https://avatars.githubusercontent.com/u/22449467?v=4?s=100" width="100px;" alt="Stuart Macleod"/><br /><sub><b>Stuart Macleod</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=stuartio" title="Code">💻</a></td>
<td align="center" valign="top" width="14.28%"><a href="https://github.com/Cole-Greer"><img src="https://avatars.githubusercontent.com/u/112986082?v=4?s=100" width="100px;" alt="Cole Greer"/><br /><sub><b>Cole Greer</b></sub></a><br /><a href="https://github.com/nodestream-proj/nodestream/commits?author=Cole-Greer" title="Code">💻</a></td>
</tr>
</tbody>
<tfoot>
<tr>
<td align="center" size="13px" colspan="7">
<img src="https://raw.githubusercontent.com/all-contributors/all-contributors-cli/1b8533af435da9854653492b1327a23a4dbd0a10/assets/logo-small.svg">
<a href="https://all-contributors.js.org/docs/en/bot/usage">Add your contributions</a>
</img>
</td>
</tr>
</tfoot>
</table>
<!-- markdownlint-restore -->
<!-- prettier-ignore-end -->
<!-- ALL-CONTRIBUTORS-LIST:END -->
### Contributing
Need a quick reference guide on how to contribute? Here you go!
#### Getting Setup
To get started you'll need to install poery.
```bash
curl -sSL https://install.python-poetry.org | python3 -
```
You then can install the project dependencies with the following command:
```bash
poetry install
```
No need to active a virtual environment. Poetry handles that for you with `poetry run` and `poetry shell`.
#### Running Tests
To run tests for the entire project, run the following command:
```bash
poetry run pytest
```
Raw data
{
"_id": null,
"home_page": "https://github.com/nodestream-proj/nodestream",
"name": "nodestream",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.10",
"maintainer_email": null,
"keywords": "etl, neo4j, declarative, data, kafka, ingest",
"author": "Zach Probst",
"author_email": "Zach_Probst@intuit.com",
"download_url": "https://files.pythonhosted.org/packages/10/87/7171a70f90d3de90450fdb0f9da2f8e866807243aaaf4c574b4a4657d9ec/nodestream-0.13.4.tar.gz",
"platform": null,
"description": "# Nodestream \n\n<picture >\n <source media=\"(prefers-color-scheme: dark)\" srcset=\"./docs/img/NodeSteamLogo_Small_Light.png\">\n <img alt=\"Nodestream Logo\" src=\"./docs/img/NodeSteamLogo_Small_Dark.png\" width=\"300\" align=\"right\">\n</picture>\n\n\n> A Declarative framework for Building, Maintaining, and Analyzing Graph Data \ud83d\ude80\n\n[![Continuous Integration](https://github.com/nodestream-proj/nodestream/actions/workflows/ci.yaml/badge.svg)](https://github.com/nodestream-proj/nodestream/actions/workflows/ci.yaml)\n[![codecov](https://codecov.io/gh/nodestream-proj/nodestream/branch/main/graph/badge.svg?token=HAPEVKQ6OQ)](https://codecov.io/gh/nodestream-proj/nodestream)\n[![ApacheV2 License](https://img.shields.io/badge/License-Apache%202.0-yellow.svg)](https://opensource.org/license/apache-2-0/)\n<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->\n[![All Contributors](https://img.shields.io/badge/all_contributors-11-orange.svg?style=flat-square)](#contributors-)\n<!-- ALL-CONTRIBUTORS-BADGE:END -->\n\n**Nodestream allows you to work with graphs declaratively.** With nodestream, you unlock a bounty of features purpose built for working with graphs. \nSemantically model your graph and map labels and properties directly to your data. \nBetter yet, you are not locked into your choices. \nNodestream works with you as you evolve your application by providing migration utilities to change your data schema. \nNodestream even decouples you from the underyling database technology so you can even change databases.\n\n#### Highlights\n\n- Connect to data sources like [Kafka](https://nodestream-proj.github.io/docs/docs/reference/extractors/#streamextractor), [files](https://nodestream-proj.github.io/docs/docs/reference/extractors/#unifiedfileextractor), [apis](https://nodestream-proj.github.io/docs/docs/reference/extractors/#simpleapiextractor), and [more](https://nodestream-proj.github.io/docs/docs/reference/extractors/)!\n- Evolve your application over time with database migrations ([Docs](https://nodestream-proj.github.io/docs/docs/tutorials-intermediate/working-with-migrations/))\n- Use your favorite Graph Database to fit any tech stack ([Docs](https://nodestream-proj.github.io/docs/docs/category/database-support/))\n- Clean up your own data with TTLs ([Docs](https://nodestream-proj.github.io/docs/docs/tutorials-intermediate/removing-data/#implementing-a-ttl-pipeline))\n- Infinite Customizability Since Nearly Everything is Pluggable!\n\n> [Website](https://nodestream-proj.github.io/docs/) \u2022 [Blog](https://nodestream-proj.github.io/docs/blog/) \u2022 [Discussions](https://github.com/orgs/nodestream-proj/discussions) \u2022 [Contributing](#contributing) \u2022 [Contributing Developer Guides](https://nodestream-proj.github.io/docs/docs/category/developer-reference/) \u2022 [Talks from Maintainers](https://www.youtube.com/watch?v=2F-xx4LcTng&list=PLUiAbWRQecSOorv_V6TzfUBoIZyf-6r6R&pp=gAQBiAQB)\n\n## Features \n\nNodestream has a pleasant CLI interface to get new projects up and running fast. \n\n![Demo](https://raw.githubusercontent.com/nodestream-proj/nodestream/e94d0faa024c0f8da1e83a4ff6d83746504d197e/docs/img/demo.gif)\n\nNot a fan of the defaults? You can change out databases very easily\n\n![Using Another Database](https://nodestream-proj.github.io/docs/assets/images/neptune-2c1c78b173e824fc1e824f54287e467f.gif)\n\nThen you can start to model your data and nodestream will evolve your database for you. No more messing with constraints or writing database queries. \n\n![Running Migrations](https://nodestream-proj.github.io/docs/assets/images/migrations-1ede1ab3d5438cdca24d66cfa6d66231.gif)\n\n## Getting Started\n\nConviced? Install nodestream with `pip` to get started. \n\n```bash\n pip install nodestream\n nodestream new --database neo4j my_project && cd my_project\n nodestream run sample -v\n```\n\nWe highly recommend following our tutorials [here](https://nodestream-proj.github.io/docs/docs/category/tutorial---basics/)\n\n## Packages \n\nNodestream is built on a Highly Pluggable and Modular Architecture. Thus... we have a lot of packages to keep track of. \n\n| Package \t| Description \t| Version \t|\n|------------------------------\t|-------------------------------------------------------------------------------\t|--------------------------------------------------------------------------------------------------------------------------------\t|\n| `nodestream` \t| The core library. Declarative ingestion. \t| ![PyPI Version](https://badge.fury.io/py/nodestream.svg) \t|\n| `nodestream-plugin-neo4j` \t| Neo4j database connector. \t| ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-neo4j.svg) \t|\n| `nodestream-plugin-neptune` \t| AWS Neptune database connector. \t| ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-neptune.svg) \t|\n| `nodestream-plugin-dotenv` \t| Adds DotEnv integration. \t| ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-dotenv.svg) \t|\n| `nodestream-plugin-pedantic` \t| A series of lints to enforce reasonable naming standards, etc. \t| ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-pedantic.svg) \t|\n| `nodestream-plugin-shell` \t| An integration with nodestream to run shell commands. \t| ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-shell.svg) \t|\n| `nodestream-plugin-sbom` \t| Import SBOM files in CycloneDX and SPDX into an opinionated graph data model. \t| ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-sbom.svg) \t|\n| `nodestream-plugin-akamai` \t| Parse Akamai properties, redirect configs, and much more and ingests them. \t| ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-akamai.svg) \t|\n| `nodestream-plugin-k8s` \t| In incubation. A plugin that orchestrates Nodestream on k8s. \t| ![PyPI Version](https://badge.fury.io/py/nodestream-plugin-k8s.svg) \t|\n\n\n## Contributors\n\nNodestream is a community project. We welcome all contributions. \nBe sure to checkout or [Contributing Docs](https://nodestream-proj.github.io/docs/docs/category/developer-reference/) and our [Code of Conduct](./CODE_OF_CONDUCT.md) before contributing. \n\n<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->\n<!-- prettier-ignore-start -->\n<!-- markdownlint-disable -->\n<table>\n <tbody>\n <tr>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/zprobst\"><img src=\"https://avatars.githubusercontent.com/u/22159145?v=4?s=100\" width=\"100px;\" alt=\"Zach Probst\"/><br /><sub><b>Zach Probst</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=zprobst\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Azprobst\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a> <a href=\"#maintenance-zprobst\" title=\"Maintenance\">\ud83d\udea7</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/ccloes\"><img src=\"https://avatars.githubusercontent.com/u/1000538?v=4?s=100\" width=\"100px;\" alt=\"Chad Cloes\"/><br /><sub><b>Chad Cloes</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=ccloes\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Accloes\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a> <a href=\"#maintenance-ccloes\" title=\"Maintenance\">\ud83d\udea7</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/angelosantos4\"><img src=\"https://avatars.githubusercontent.com/u/142852840?v=4?s=100\" width=\"100px;\" alt=\"asantos4\"/><br /><sub><b>asantos4</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=angelosantos4\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Aangelosantos4\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a> <a href=\"#maintenance-angelosantos4\" title=\"Maintenance\">\ud83d\udea7</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/grantleehoffman\"><img src=\"https://avatars.githubusercontent.com/u/603848?v=4?s=100\" width=\"100px;\" alt=\"Grant Hoffman\"/><br /><sub><b>Grant Hoffman</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=grantleehoffman\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Agrantleehoffman\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/khneal\"><img src=\"https://avatars.githubusercontent.com/u/40273388?v=4?s=100\" width=\"100px;\" alt=\"khneal\"/><br /><sub><b>khneal</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=khneal\" title=\"Code\">\ud83d\udcbb</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/orozen\"><img src=\"https://avatars.githubusercontent.com/u/62594754?v=4?s=100\" width=\"100px;\" alt=\"orozen\"/><br /><sub><b>orozen</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=orozen\" title=\"Code\">\ud83d\udcbb</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://sites.google.com/view/ai4allrobotics\"><img src=\"https://avatars.githubusercontent.com/u/66497192?v=4?s=100\" width=\"100px;\" alt=\"Sophia Don Tranho\"/><br /><sub><b>Sophia Don Tranho</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=sophiadt\" title=\"Code\">\ud83d\udcbb</a></td>\n </tr>\n <tr>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/bechbd\"><img src=\"https://avatars.githubusercontent.com/u/6898505?v=4?s=100\" width=\"100px;\" alt=\"bechbd\"/><br /><sub><b>bechbd</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=bechbd\" title=\"Code\">\ud83d\udcbb</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/yasonk\"><img src=\"https://avatars.githubusercontent.com/u/6750414?v=4?s=100\" width=\"100px;\" alt=\"yasonk\"/><br /><sub><b>yasonk</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=yasonk\" title=\"Code\">\ud83d\udcbb</a> <a href=\"https://github.com/nodestream-proj/nodestream/pulls?q=is%3Apr+reviewed-by%3Ayasonk\" title=\"Reviewed Pull Requests\">\ud83d\udc40</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/stuartio\"><img src=\"https://avatars.githubusercontent.com/u/22449467?v=4?s=100\" width=\"100px;\" alt=\"Stuart Macleod\"/><br /><sub><b>Stuart Macleod</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=stuartio\" title=\"Code\">\ud83d\udcbb</a></td>\n <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"https://github.com/Cole-Greer\"><img src=\"https://avatars.githubusercontent.com/u/112986082?v=4?s=100\" width=\"100px;\" alt=\"Cole Greer\"/><br /><sub><b>Cole Greer</b></sub></a><br /><a href=\"https://github.com/nodestream-proj/nodestream/commits?author=Cole-Greer\" title=\"Code\">\ud83d\udcbb</a></td>\n </tr>\n </tbody>\n <tfoot>\n <tr>\n <td align=\"center\" size=\"13px\" colspan=\"7\">\n <img src=\"https://raw.githubusercontent.com/all-contributors/all-contributors-cli/1b8533af435da9854653492b1327a23a4dbd0a10/assets/logo-small.svg\">\n <a href=\"https://all-contributors.js.org/docs/en/bot/usage\">Add your contributions</a>\n </img>\n </td>\n </tr>\n </tfoot>\n</table>\n\n<!-- markdownlint-restore -->\n<!-- prettier-ignore-end -->\n\n<!-- ALL-CONTRIBUTORS-LIST:END -->\n\n### Contributing \n\nNeed a quick reference guide on how to contribute? Here you go!\n\n#### Getting Setup \n\nTo get started you'll need to install poery.\n\n```bash\ncurl -sSL https://install.python-poetry.org | python3 -\n```\n\nYou then can install the project dependencies with the following command:\n\n```bash\npoetry install\n```\n\nNo need to active a virtual environment. Poetry handles that for you with `poetry run` and `poetry shell`.\n\n#### Running Tests\n\nTo run tests for the entire project, run the following command:\n\n```bash\npoetry run pytest\n```\n\n",
"bugtrack_url": null,
"license": "GPL-3.0-only",
"summary": "A Fast, Declarative ETL for Graph Databases.",
"version": "0.13.4",
"project_urls": {
"Documentation": "https://nodestream-proj.github.io/nodestream",
"Homepage": "https://github.com/nodestream-proj/nodestream",
"Repository": "https://github.com/nodestream-proj/nodestream"
},
"split_keywords": [
"etl",
" neo4j",
" declarative",
" data",
" kafka",
" ingest"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "4607558bb43311ff33ac4db8380929bbf58a3efd0acb76752f7a0d05f68caf0c",
"md5": "bea646c58960d3dbd35c70c5f7246244",
"sha256": "7cde5000eed2cb4abab2a85498b3be7dc48cdc87218dbd82d55982cde54d1148"
},
"downloads": -1,
"filename": "nodestream-0.13.4-py3-none-any.whl",
"has_sig": false,
"md5_digest": "bea646c58960d3dbd35c70c5f7246244",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.10",
"size": 157162,
"upload_time": "2024-11-20T14:33:29",
"upload_time_iso_8601": "2024-11-20T14:33:29.757819Z",
"url": "https://files.pythonhosted.org/packages/46/07/558bb43311ff33ac4db8380929bbf58a3efd0acb76752f7a0d05f68caf0c/nodestream-0.13.4-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "10877171a70f90d3de90450fdb0f9da2f8e866807243aaaf4c574b4a4657d9ec",
"md5": "66b1d670e992d9898d73a95066ba3d8b",
"sha256": "243c76144c21cf270871dbe3900cd526e06cbcc808ac086a7ae06d338729c6c3"
},
"downloads": -1,
"filename": "nodestream-0.13.4.tar.gz",
"has_sig": false,
"md5_digest": "66b1d670e992d9898d73a95066ba3d8b",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.10",
"size": 104449,
"upload_time": "2024-11-20T14:33:31",
"upload_time_iso_8601": "2024-11-20T14:33:31.850126Z",
"url": "https://files.pythonhosted.org/packages/10/87/7171a70f90d3de90450fdb0f9da2f8e866807243aaaf4c574b4a4657d9ec/nodestream-0.13.4.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-11-20 14:33:31",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "nodestream-proj",
"github_project": "nodestream",
"travis_ci": false,
"coveralls": true,
"github_actions": true,
"lcname": "nodestream"
}