ternyxmimosa


Nameternyxmimosa JSON
Version 0.6.0 PyPI version JSON
download
home_pagehttps://github.com/EJOOSTEROP/mimosa
SummaryA minimal modern data stack with working data pipelines in a single Docker container.
upload_time2024-08-03 20:11:26
maintainerNone
docs_urlNone
authorErik Oosterop
requires_python<3.13,>=3.11
licenseMIT
keywords x y z
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <!-- Inspired by https://github.com/othneildrew/Best-README-Template/blob/master/BLANK_README.md -->

<a name="readme-top"></a>


<!-- SHIELDS HEADER -->
<div align="center">


[![contributors-shield]][contributors-url] [![Forks][forks-shield]][forks-url] [![Stargazers][stars-shield]][stars-url] [![Issues][issues-shield]][issues-url] [![MIT License][license-shield]][license-url] [![LinkedIn][linkedin-shield]][linkedin-url]

[contributors-shield]: https://img.shields.io/github/contributors/EJOOSTEROP/mimosa.svg?logo=github
[contributors-url]: https://github.com/EJOOSTEROP/mimosa/graphs/contributors

[forks-shield]: https://img.shields.io/github/forks/EJOOSTEROP/mimosa.svg?logo=github
[forks-url]: https://github.com/EJOOSTEROP/mimosa/network/members

[stars-shield]: https://img.shields.io/github/stars/EJOOSTEROP/mimosa.svg?logo=github
[stars-url]: https://github.com/EJOOSTEROP/mimosa/stargazers

[issues-shield]: https://img.shields.io/github/issues/EJOOSTEROP/mimosa.svg?logo=github
[issues-url]: https://github.com/EJOOSTEROP/mimosa/issues

[license-shield]: https://img.shields.io/github/license/EJOOSTEROP/mimosa.svg?logo=github
[license-url]: https://github.com/EJOOSTEROP/mimosa/blob/main/LICENSE.txt

[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?logo=linkedin&colorB=555
[linkedin-url]: https://linkedin.com/in/erik-oosterop-9505a21

[![current release](https://img.shields.io/github/release/ejoosterop/mimosa.svg)](https://github.com/ejoosterop/mimosa/releases)

<!-- no PyPi repository
[![PyPI - Python Version][pypi-python-shield]][https://pypi.org/project/x_mimosa_x]

[pypi-python-shield]: https://img.shields.io/pypi/pyversions/mimosa?logo=python


[![PyPi - Package Version][pypi-version-shield]][https://pypi.org/project/x_mimosa_x]

[pypi-version-shield]: https://img.shields.io/pypi/v/mimosa?logo=python


[![PyPi - License][pypi-license-shield]][license-url]

[pypi-license-shield]: https://img.shields.io/pypi/l/mimosa?logo=python
-->
</div>

<!-- PROJECT SUMMARY AND LOGO -->
<div align="center">
  <a href="https://github.com/EJOOSTEROP/mimosa">
    <img src="https://github.com/EJOOSTEROP/mimosa/blob/main/etc/logo.png?raw=true" alt="Logo" width="180" height="180">
  </a>

<h3 align="center">mimosa</h3>

  <p align="center">
    The ELT part of a modern data stack with practical data pipelines using cloud functionality.
    <br />
    <a href="https://github.com/EJOOSTEROP/mimosa"><strong>Explore the docs ยป</strong></a>
    <br />
    <br />
    <!--
    <a href="https://github.com/EJOOSTEROP/mimosa">View Demo</a>
    ยท
    -->
    <a href="https://github.com/EJOOSTEROP/mimosa/issues">Report Bug</a>
    ยท
    <a href="https://github.com/EJOOSTEROP/mimosa/issues">Request Feature</a>
  </p>
</div>


<!-- TABLE OF CONTENTS -->
<br />
<details>
  <summary>Table of Contents</summary>
  <ol>
    <li>
      <a href="#about-the-project">About the Project</a>
      <!-- <ul>
        <li><a href="#built-with">Built With</a></li>
      </ul> -->
    </li>
    <li>
      <a href="#getting-started">Getting Started</a>
      <ul>
        <li><a href="#prerequisites">Prerequisites</a></li>
        <li><a href="#api-keys">API Keys</a></li>
        <li><a href="#installation">Installation</a></li>
      </ul>
    </li>
    <li><a href="#usage">Usage</a></li>
    <li><a href="#roadmap">Roadmap</a></li>
    <li><a href="#contributing">Contributing</a></li>
    <!-- <li><a href="#license">License</a></li> -->
    <li><a href="#contact">Contact</a></li>
    <!-- <li><a href="#acknowledgments">Acknowledgments</a></li> -->
  </ol>
</details>

<p align="right">(<a href="#readme-top">back to top</a>)</p>


<!-- ABOUT THE PROJECT -->
## About the Project

<div  align="center">
  <a href="https://github.com/EJOOSTEROP/mimosa">
    <img src="https://github.com/EJOOSTEROP/mimosa/blob/main/etc/intro_image.jpg?raw=true" alt="intro_image" width="75%" height="75%" title="AI generated image. Misleading image showing above ground gas storage facilities.">
  </a>
</div>

<div>

<br /><br />
The ELT part of a modern data stack with practical data pipelines and reporting using cloud functionality. This is similar in concept to [mimodast][mimodast-repo-url] using alternative software options and cloud functionality.
<!-- MIMOdast Software Alternatives -->

Mimosa encompasses the ELT (extract load transform) components necessary to generate the webpage found at [gas.aspireto.win][aspireto-gas-url], providing detailed reports on natural gas storage volumes within the European Union. This process involves retrieving data from a REST API, transforming it, and storing it in a database tailored for reporting purposes.

The source data is published by [Gas Infrastructure Europe][GIE-URL] and exposed in a REST API.

Beyond gas storage data, Mimosa offers a hands-on experience with essential tools:
- ๐Ÿš€ [dlt][dlthub-url] for smooth data loading.
- ๐Ÿ” [dbt][dbt-url] for powerful data transformation.
- โ˜๏ธ [MotherDuck][motherduck-url]  for storing the data in a cloud based [DuckDB][DuckDB-url] database.

Further the full tech stack used to create the [gas.aspireto.win][aspireto-gas-url] pages is detailed <a href="#tech-stack">below</a>.
</div>

<br />

<div>
  <a href="https://gas.aspireto.win">
  <img src="https://github.com/EJOOSTEROP/mimosa/blob/main/etc/web_print.png?raw=true" alt="Screenshot of gas reporting at https://gas.apireto.win." width="75%" height="75%">
  </a>
</div>

<p align="right">(<a href="#readme-top">back to top</a>)</p>


<!-- BUILT WITH -->
<!--
### Built With

<p align="right">(<a href="#readme-top">back to top</a>)</p>
-->


<!-- GETTING STARTED -->
## Getting Started

<!--To get a local copy up and running follow these simple example steps.
-->

### Prerequisites

Setup a Python development environment.

### API Keys

Ensure the following sensitive information is securely stored in environment variables or within a .env file:

- To access the [GIE Gas Inventory][GIEAPI-url] REST API, an API key is necessary. Quickly obtain your API key by signing up for a free [GIE account][GIEAccount-url]. Once acquired, expose it using the following environment variable:

  - ENV_GIE_XKEY = "YOUR-API-KEY"
- For [MotherDuck][motherduck-url], you'll need the [service token][motherduck-token-url] and the database name. Set up the following environment variables to establish the connection:

  - DESTINATION__MOTHERDUCK__CREDENTIALS = "md:///YOUR-DATABASE-NAME?token=YOUR-SERVICE-TOKEN"
  - Please note that the [MotherDuck][motherduck-url] page utilizes a different format, whereas the above format is specifically required for [dlt][dlthub-url].

<p align="right">(<a href="#readme-top">back to top</a>)</p>

### Installation

Execute the following command. Consider using a venv.
```shell
pip install ternyxmimosa
```

Alternatively clone this repository and use `poetry install`. Or pip install from GitHub.

<p align="right">(<a href="#readme-top">back to top</a>)</p>


<!-- USAGE EXAMPLES -->
## Usage

### Command Line
Not currently supported.

### As a Python Package

The following sample obtains the storage data for the last available date and stores it in MotherDuck.

```python
import mimosa.cli as GEI

GEI.main()
```

### Tech Stack

These are the technologies driving the content on [gas.aspireto.win][aspireto-gas-url]:
- **Google cloud** [function](https://cloud.google.com/functions) for the ELT component:
  - The function is a bare bones wrapper around the [mimosa][mimosa-repo-url] Python package (the current repository). The function is in this [repository][cloud-func-repo-url].
  - It is scheduled to run the ELT twice daily (using Google Scheduler and [Pub/Sub](https://cloud.google.com/pubsub) message).
  - The result is updated data in MotherDuck.
- **Reporting notebook**
  - Built using the [evidence](https://evidence.dev/) reporting tool, defined in this GitHub [repository](https://github.com/EJOOSTEROP/gie-evidence-dash).
  - Rebuild and published to a web host using a GitHub workflow.
    - Run on a twice daily schedule. The workflow is defined in the notebook [repository](https://github.com/EJOOSTEROP/gie-evidence-dash).


NOTE: As of November 2023 it is possible to fully deploy this stack without breaking the bank (using free tiers of the cloud services used). Dive into our GitHub repository and the linked ones for the Google Function and Evidence notebook, where all the code awaits. ๐Ÿš€

### Sentry
To enable logging iusing sentry.io specify the environment variable ```RUNTIME__SENTRY_DSN```

<p align="right">(<a href="#readme-top">back to top</a>)</p>

NOTE: For some reason the environment variable DESTINATION__MOTHERDUCK__CREDENTIALS is oftentimes incorrectly set between runs when using the dev container. Use ```unset DESTINATION__MOTHERDUCK__CREDENTIALS``` to clear the environment variable.

<!-- ROADMAP -->
## Roadmap

<div>
Consider:

- [x] Get source data (Using REST API)
- [x] Transform data, possibly SQL Mesh or dbt.
  - [ ] Create data vault transformations (https://automate-dv.readthedocs.io/en/latest/).
- [ ] dlt update/error messages using Slack
- [x] Storage (currently local DuckDB, maybe consider some cloud alternative. Though that would stray from the data stack in a Docker concept.) (MotherDuck)
- [x] Scheduling Tool (Google Cloud Scheduler)
- [x] Reporting tool (Metabase?) (Evidence.dev in separate repository)
- [ ] Bare bones CLI
</div>

<p align="right">(<a href="#readme-top">back to top</a>)</p>


<!-- CONTRIBUTING -->
## Contributing

<!-- Contributions are what make the open source community such an amazing place to learn, inspire, and create. -->
Any contributions you make are **greatly appreciated**.

If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also [open](https://github.com/EJOOSTEROP/mimosa/issues/new/choose) a feature request or bug report.
Don't forget to give the project a star! Thanks again!

1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request

<p align="right">(<a href="#readme-top">back to top</a>)</p>


<!-- LICENSE -->
<!--
## License

Distributed under the MIT License. See `LICENSE.txt` for more information. The tools and the sample data are subject to their own respective licenses.

<p align="right">(<a href="#readme-top">back to top</a>)</p>
-->


<!-- CONTACT -->
## Contact

<!--
Your Name - [@twitter_handle](https://twitter.com/twitter_handle) - email@email_client.com
-->

Project Link: [mimosa](https://github.com/EJOOSTEROP/mimosa)

<p align="right">(<a href="#readme-top">back to top</a>)</p>


<!-- ACKNOWLEDGMENTS -->
<!--
## Acknowledgments

* []()
* []()
* []()

<p align="right">(<a href="#readme-top">back to top</a>)</p>

-->

<!-- MARKDOWN LINKS & IMAGES -->
<!-- https://www.markdownguide.org/basic-syntax/#reference-style-links -->

[aspireto-gas-url]: https://gas.aspireto.win

[mimodast-repo-url]: https://github.com/EJOOSTEROP/mimodast
[mimosa-repo-url]: https://github.com/EJOOSTEROP/mimosa
[cloud-func-repo-url]: https://github.com/EJOOSTEROP/gie-gcp-func
[dlthub-url]: https://dlthub.com/
[dbt-url]: https://www.getdbt.com
[motherduck-url]: https://motherduck.com/
[motherduck-token-url]: https://motherduck.com/docs/authenticating-to-motherduck/#authentication-using-a-service-token
[DuckDB-url]: https://duckdb.org

[GIE-URL]: https://www.gie.eu/
[GIEAPI-url]: https://agsi.gie.eu/
[GIEAccount-url]: https://agsi.gie.eu/account
            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/EJOOSTEROP/mimosa",
    "name": "ternyxmimosa",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<3.13,>=3.11",
    "maintainer_email": null,
    "keywords": "x, y, z",
    "author": "Erik Oosterop",
    "author_email": "erik.oosterop.khesw@aleeas.com",
    "download_url": "https://files.pythonhosted.org/packages/e7/4f/82eea5327dc18362666fd276a1a90adf05e7d5b9dffc7f01772fd4b76f47/ternyxmimosa-0.6.0.tar.gz",
    "platform": null,
    "description": "<!-- Inspired by https://github.com/othneildrew/Best-README-Template/blob/master/BLANK_README.md -->\n\n<a name=\"readme-top\"></a>\n\n\n<!-- SHIELDS HEADER -->\n<div align=\"center\">\n\n\n[![contributors-shield]][contributors-url] [![Forks][forks-shield]][forks-url] [![Stargazers][stars-shield]][stars-url] [![Issues][issues-shield]][issues-url] [![MIT License][license-shield]][license-url] [![LinkedIn][linkedin-shield]][linkedin-url]\n\n[contributors-shield]: https://img.shields.io/github/contributors/EJOOSTEROP/mimosa.svg?logo=github\n[contributors-url]: https://github.com/EJOOSTEROP/mimosa/graphs/contributors\n\n[forks-shield]: https://img.shields.io/github/forks/EJOOSTEROP/mimosa.svg?logo=github\n[forks-url]: https://github.com/EJOOSTEROP/mimosa/network/members\n\n[stars-shield]: https://img.shields.io/github/stars/EJOOSTEROP/mimosa.svg?logo=github\n[stars-url]: https://github.com/EJOOSTEROP/mimosa/stargazers\n\n[issues-shield]: https://img.shields.io/github/issues/EJOOSTEROP/mimosa.svg?logo=github\n[issues-url]: https://github.com/EJOOSTEROP/mimosa/issues\n\n[license-shield]: https://img.shields.io/github/license/EJOOSTEROP/mimosa.svg?logo=github\n[license-url]: https://github.com/EJOOSTEROP/mimosa/blob/main/LICENSE.txt\n\n[linkedin-shield]: https://img.shields.io/badge/-LinkedIn-black.svg?logo=linkedin&colorB=555\n[linkedin-url]: https://linkedin.com/in/erik-oosterop-9505a21\n\n[![current release](https://img.shields.io/github/release/ejoosterop/mimosa.svg)](https://github.com/ejoosterop/mimosa/releases)\n\n<!-- no PyPi repository\n[![PyPI - Python Version][pypi-python-shield]][https://pypi.org/project/x_mimosa_x]\n\n[pypi-python-shield]: https://img.shields.io/pypi/pyversions/mimosa?logo=python\n\n\n[![PyPi - Package Version][pypi-version-shield]][https://pypi.org/project/x_mimosa_x]\n\n[pypi-version-shield]: https://img.shields.io/pypi/v/mimosa?logo=python\n\n\n[![PyPi - License][pypi-license-shield]][license-url]\n\n[pypi-license-shield]: https://img.shields.io/pypi/l/mimosa?logo=python\n-->\n</div>\n\n<!-- PROJECT SUMMARY AND LOGO -->\n<div align=\"center\">\n  <a href=\"https://github.com/EJOOSTEROP/mimosa\">\n    <img src=\"https://github.com/EJOOSTEROP/mimosa/blob/main/etc/logo.png?raw=true\" alt=\"Logo\" width=\"180\" height=\"180\">\n  </a>\n\n<h3 align=\"center\">mimosa</h3>\n\n  <p align=\"center\">\n    The ELT part of a modern data stack with practical data pipelines using cloud functionality.\n    <br />\n    <a href=\"https://github.com/EJOOSTEROP/mimosa\"><strong>Explore the docs \u00bb</strong></a>\n    <br />\n    <br />\n    <!--\n    <a href=\"https://github.com/EJOOSTEROP/mimosa\">View Demo</a>\n    \u00b7\n    -->\n    <a href=\"https://github.com/EJOOSTEROP/mimosa/issues\">Report Bug</a>\n    \u00b7\n    <a href=\"https://github.com/EJOOSTEROP/mimosa/issues\">Request Feature</a>\n  </p>\n</div>\n\n\n<!-- TABLE OF CONTENTS -->\n<br />\n<details>\n  <summary>Table of Contents</summary>\n  <ol>\n    <li>\n      <a href=\"#about-the-project\">About the Project</a>\n      <!-- <ul>\n        <li><a href=\"#built-with\">Built With</a></li>\n      </ul> -->\n    </li>\n    <li>\n      <a href=\"#getting-started\">Getting Started</a>\n      <ul>\n        <li><a href=\"#prerequisites\">Prerequisites</a></li>\n        <li><a href=\"#api-keys\">API Keys</a></li>\n        <li><a href=\"#installation\">Installation</a></li>\n      </ul>\n    </li>\n    <li><a href=\"#usage\">Usage</a></li>\n    <li><a href=\"#roadmap\">Roadmap</a></li>\n    <li><a href=\"#contributing\">Contributing</a></li>\n    <!-- <li><a href=\"#license\">License</a></li> -->\n    <li><a href=\"#contact\">Contact</a></li>\n    <!-- <li><a href=\"#acknowledgments\">Acknowledgments</a></li> -->\n  </ol>\n</details>\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\n\n<!-- ABOUT THE PROJECT -->\n## About the Project\n\n<div  align=\"center\">\n  <a href=\"https://github.com/EJOOSTEROP/mimosa\">\n    <img src=\"https://github.com/EJOOSTEROP/mimosa/blob/main/etc/intro_image.jpg?raw=true\" alt=\"intro_image\" width=\"75%\" height=\"75%\" title=\"AI generated image. Misleading image showing above ground gas storage facilities.\">\n  </a>\n</div>\n\n<div>\n\n<br /><br />\nThe ELT part of a modern data stack with practical data pipelines and reporting using cloud functionality. This is similar in concept to [mimodast][mimodast-repo-url] using alternative software options and cloud functionality.\n<!-- MIMOdast Software Alternatives -->\n\nMimosa encompasses the ELT (extract load transform) components necessary to generate the webpage found at [gas.aspireto.win][aspireto-gas-url], providing detailed reports on natural gas storage volumes within the European Union. This process involves retrieving data from a REST API, transforming it, and storing it in a database tailored for reporting purposes.\n\nThe source data is published by [Gas Infrastructure Europe][GIE-URL] and exposed in a REST API.\n\nBeyond gas storage data, Mimosa offers a hands-on experience with essential tools:\n- \ud83d\ude80 [dlt][dlthub-url] for smooth data loading.\n- \ud83d\udd0d [dbt][dbt-url] for powerful data transformation.\n- \u2601\ufe0f [MotherDuck][motherduck-url]  for storing the data in a cloud based [DuckDB][DuckDB-url] database.\n\nFurther the full tech stack used to create the [gas.aspireto.win][aspireto-gas-url] pages is detailed <a href=\"#tech-stack\">below</a>.\n</div>\n\n<br />\n\n<div>\n  <a href=\"https://gas.aspireto.win\">\n  <img src=\"https://github.com/EJOOSTEROP/mimosa/blob/main/etc/web_print.png?raw=true\" alt=\"Screenshot of gas reporting at https://gas.apireto.win.\" width=\"75%\" height=\"75%\">\n  </a>\n</div>\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\n\n<!-- BUILT WITH -->\n<!--\n### Built With\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n-->\n\n\n<!-- GETTING STARTED -->\n## Getting Started\n\n<!--To get a local copy up and running follow these simple example steps.\n-->\n\n### Prerequisites\n\nSetup a Python development environment.\n\n### API Keys\n\nEnsure the following sensitive information is securely stored in environment variables or within a .env file:\n\n- To access the [GIE Gas Inventory][GIEAPI-url] REST API, an API key is necessary. Quickly obtain your API key by signing up for a free [GIE account][GIEAccount-url]. Once acquired, expose it using the following environment variable:\n\n  - ENV_GIE_XKEY = \"YOUR-API-KEY\"\n- For [MotherDuck][motherduck-url], you'll need the [service token][motherduck-token-url] and the database name. Set up the following environment variables to establish the connection:\n\n  - DESTINATION__MOTHERDUCK__CREDENTIALS = \"md:///YOUR-DATABASE-NAME?token=YOUR-SERVICE-TOKEN\"\n  - Please note that the [MotherDuck][motherduck-url] page utilizes a different format, whereas the above format is specifically required for [dlt][dlthub-url].\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\n### Installation\n\nExecute the following command. Consider using a venv.\n```shell\npip install ternyxmimosa\n```\n\nAlternatively clone this repository and use `poetry install`. Or pip install from GitHub.\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\n\n<!-- USAGE EXAMPLES -->\n## Usage\n\n### Command Line\nNot currently supported.\n\n### As a Python Package\n\nThe following sample obtains the storage data for the last available date and stores it in MotherDuck.\n\n```python\nimport mimosa.cli as GEI\n\nGEI.main()\n```\n\n### Tech Stack\n\nThese are the technologies driving the content on [gas.aspireto.win][aspireto-gas-url]:\n- **Google cloud** [function](https://cloud.google.com/functions) for the ELT component:\n  - The function is a bare bones wrapper around the [mimosa][mimosa-repo-url] Python package (the current repository). The function is in this [repository][cloud-func-repo-url].\n  - It is scheduled to run the ELT twice daily (using Google Scheduler and [Pub/Sub](https://cloud.google.com/pubsub) message).\n  - The result is updated data in MotherDuck.\n- **Reporting notebook**\n  - Built using the [evidence](https://evidence.dev/) reporting tool, defined in this GitHub [repository](https://github.com/EJOOSTEROP/gie-evidence-dash).\n  - Rebuild and published to a web host using a GitHub workflow.\n    - Run on a twice daily schedule. The workflow is defined in the notebook [repository](https://github.com/EJOOSTEROP/gie-evidence-dash).\n\n\nNOTE: As of November 2023 it is possible to fully deploy this stack without breaking the bank (using free tiers of the cloud services used). Dive into our GitHub repository and the linked ones for the Google Function and Evidence notebook, where all the code awaits. \ud83d\ude80\n\n### Sentry\nTo enable logging iusing sentry.io specify the environment variable ```RUNTIME__SENTRY_DSN```\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\nNOTE: For some reason the environment variable DESTINATION__MOTHERDUCK__CREDENTIALS is oftentimes incorrectly set between runs when using the dev container. Use ```unset DESTINATION__MOTHERDUCK__CREDENTIALS``` to clear the environment variable.\n\n<!-- ROADMAP -->\n## Roadmap\n\n<div>\nConsider:\n\n- [x] Get source data (Using REST API)\n- [x] Transform data, possibly SQL Mesh or dbt.\n  - [ ] Create data vault transformations (https://automate-dv.readthedocs.io/en/latest/).\n- [ ] dlt update/error messages using Slack\n- [x] Storage (currently local DuckDB, maybe consider some cloud alternative. Though that would stray from the data stack in a Docker concept.) (MotherDuck)\n- [x] Scheduling Tool (Google Cloud Scheduler)\n- [x] Reporting tool (Metabase?) (Evidence.dev in separate repository)\n- [ ] Bare bones CLI\n</div>\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\n\n<!-- CONTRIBUTING -->\n## Contributing\n\n<!-- Contributions are what make the open source community such an amazing place to learn, inspire, and create. -->\nAny contributions you make are **greatly appreciated**.\n\nIf you have a suggestion that would make this better, please fork the repo and create a pull request. You can also [open](https://github.com/EJOOSTEROP/mimosa/issues/new/choose) a feature request or bug report.\nDon't forget to give the project a star! Thanks again!\n\n1. Fork the Project\n2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)\n3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)\n4. Push to the Branch (`git push origin feature/AmazingFeature`)\n5. Open a Pull Request\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\n\n<!-- LICENSE -->\n<!--\n## License\n\nDistributed under the MIT License. See `LICENSE.txt` for more information. The tools and the sample data are subject to their own respective licenses.\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n-->\n\n\n<!-- CONTACT -->\n## Contact\n\n<!--\nYour Name - [@twitter_handle](https://twitter.com/twitter_handle) - email@email_client.com\n-->\n\nProject Link: [mimosa](https://github.com/EJOOSTEROP/mimosa)\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\n\n<!-- ACKNOWLEDGMENTS -->\n<!--\n## Acknowledgments\n\n* []()\n* []()\n* []()\n\n<p align=\"right\">(<a href=\"#readme-top\">back to top</a>)</p>\n\n-->\n\n<!-- MARKDOWN LINKS & IMAGES -->\n<!-- https://www.markdownguide.org/basic-syntax/#reference-style-links -->\n\n[aspireto-gas-url]: https://gas.aspireto.win\n\n[mimodast-repo-url]: https://github.com/EJOOSTEROP/mimodast\n[mimosa-repo-url]: https://github.com/EJOOSTEROP/mimosa\n[cloud-func-repo-url]: https://github.com/EJOOSTEROP/gie-gcp-func\n[dlthub-url]: https://dlthub.com/\n[dbt-url]: https://www.getdbt.com\n[motherduck-url]: https://motherduck.com/\n[motherduck-token-url]: https://motherduck.com/docs/authenticating-to-motherduck/#authentication-using-a-service-token\n[DuckDB-url]: https://duckdb.org\n\n[GIE-URL]: https://www.gie.eu/\n[GIEAPI-url]: https://agsi.gie.eu/\n[GIEAccount-url]: https://agsi.gie.eu/account",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "A minimal modern data stack with working data pipelines in a single Docker container.",
    "version": "0.6.0",
    "project_urls": {
        "Documentation": "https://github.com/EJOOSTEROP/mimosa",
        "Homepage": "https://github.com/EJOOSTEROP/mimosa",
        "Repository": "https://github.com/EJOOSTEROP/mimosa"
    },
    "split_keywords": [
        "x",
        " y",
        " z"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "351cf72ac9113b95a79d7911a74c922c0a001c182806af38aed25b6d629c3f4f",
                "md5": "59bc57f7351e061fe63d2cd37f2ff844",
                "sha256": "6bfb076c16a2e64165f2680cfa77a90194ee6bf026443360e6b5bbf523bdd1c8"
            },
            "downloads": -1,
            "filename": "ternyxmimosa-0.6.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "59bc57f7351e061fe63d2cd37f2ff844",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<3.13,>=3.11",
            "size": 42601,
            "upload_time": "2024-08-03T20:11:25",
            "upload_time_iso_8601": "2024-08-03T20:11:25.051288Z",
            "url": "https://files.pythonhosted.org/packages/35/1c/f72ac9113b95a79d7911a74c922c0a001c182806af38aed25b6d629c3f4f/ternyxmimosa-0.6.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e74f82eea5327dc18362666fd276a1a90adf05e7d5b9dffc7f01772fd4b76f47",
                "md5": "518606183e000ceb0032a3f4d74b1a87",
                "sha256": "7d56cef80dd2a6197061d43b2d37d8556772138ab985b63febdf4e1cdee57cdc"
            },
            "downloads": -1,
            "filename": "ternyxmimosa-0.6.0.tar.gz",
            "has_sig": false,
            "md5_digest": "518606183e000ceb0032a3f4d74b1a87",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<3.13,>=3.11",
            "size": 42137,
            "upload_time": "2024-08-03T20:11:26",
            "upload_time_iso_8601": "2024-08-03T20:11:26.591292Z",
            "url": "https://files.pythonhosted.org/packages/e7/4f/82eea5327dc18362666fd276a1a90adf05e7d5b9dffc7f01772fd4b76f47/ternyxmimosa-0.6.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-08-03 20:11:26",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "EJOOSTEROP",
    "github_project": "mimosa",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "ternyxmimosa"
}
        
Elapsed time: 0.45333s