Metadata-Version: 2.4
Name: singer-sdk
Version: 0.53.2
Summary: A framework for building Singer taps and targets
Project-URL: Homepage, https://sdk.meltano.com/en/latest/
Project-URL: Repository, https://github.com/meltano/sdk
Project-URL: Documentation, https://sdk.meltano.com/en/latest/
Project-URL: Issue Tracker, https://github.com/meltano/sdk/issues
Project-URL: Twitter, https://twitter.com/meltanodata/
Project-URL: Changelog, https://github.com/meltano/sdk/blob/main/CHANGELOG.md
Project-URL: Slack, https://meltano.com/slack
Project-URL: Youtube, https://www.youtube.com/meltano
Author-email: Meltano Team and Contributors <hello@meltano.com>
Maintainer-email: Meltano Team and Contributors <hello@meltano.com>
License-Expression: Apache-2.0
License-File: LICENSE
Keywords: ELT,Meltano,Meltano SDK,Singer,Singer SDK
Classifier: Intended Audience :: Developers
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3.14
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Topic :: Software Development :: Libraries :: Application Frameworks
Classifier: Typing :: Typed
Requires-Python: >=3.10
Requires-Dist: backports-datetime-fromisoformat>=2.0.1; python_version < '3.11'
Requires-Dist: click<9,>=8.2
Requires-Dist: fsspec>=2024.9.0
Requires-Dist: importlib-metadata>=6.5; python_version < '3.12'
Requires-Dist: inflection>=0.5.1
Requires-Dist: joblib>=1.3.0
Requires-Dist: jsonpath-ng>=1.5.3
Requires-Dist: jsonschema>=4.16.0
Requires-Dist: packaging>=23.1
Requires-Dist: python-backoff>=2.2.2
Requires-Dist: python-dotenv>=0.20
Requires-Dist: pyyaml>=6.0
Requires-Dist: referencing>=0.30.0
Requires-Dist: requests>=2.25.1
Requires-Dist: simpleeval!=1.0.1,>=0.9.13
Requires-Dist: simplejson>=3.17.6
Requires-Dist: sqlalchemy>=2
Requires-Dist: typing-extensions>=4.5.0; python_version < '3.13'
Requires-Dist: universal-pathlib>=0.2.6
Provides-Extra: faker
Requires-Dist: faker>=22.5; extra == 'faker'
Provides-Extra: jwt
Requires-Dist: cryptography>=3.4.6; extra == 'jwt'
Requires-Dist: pyjwt>=2.4.0; extra == 'jwt'
Provides-Extra: msgspec
Requires-Dist: msgspec>=0.19.0; extra == 'msgspec'
Provides-Extra: parquet
Requires-Dist: pyarrow>=15; extra == 'parquet'
Provides-Extra: s3
Requires-Dist: s3fs>=2024.9.0; extra == 's3'
Provides-Extra: sql
Requires-Dist: sqlalchemy>=2; extra == 'sql'
Provides-Extra: ssh
Requires-Dist: paramiko>=3.3.0; extra == 'ssh'
Provides-Extra: testing
Requires-Dist: pytest>=9; extra == 'testing'
Description-Content-Type: text/markdown

<h1 align="center">Meltano Singer SDK</h1>

<h3 align="center">
The Tap and Target SDKs are the fastest way to build custom data extractors and loaders!
Taps and targets built on the SDK are automatically compliant with the
<a href="https://hub.meltano.com/singer/spec">Singer Spec</a>, the
de-facto open source standard for extract and load pipelines.
</h3>

______________________________________________________________________

</br>

<div align="center">
  <img alt="Meltano Singer SDK Logo" src="https://user-images.githubusercontent.com/11428666/231584532-ffa694e6-60f9-4fd6-b2ee-5ff3e39d3ad6.svg" width="600"/>
</div>

</br>

<div align="center">
  <a href="https://meltano.com/slack">
    <img alt="Meltano Community Slack" src="https://img.shields.io/badge/Slack-Join%20the%20Community-blue?logo=slack&labelColor=471E80&color=110B1E"/>
  </a>
  <a href="https://pypi.org/project/singer-sdk">
   <img alt="Python Versions" src="https://img.shields.io/pypi/pyversions/singer-sdk?label=Python%20Versions&labelColor=471E80&color=110B1E"/>
  </a>
  <a href="https://pypi.org/project/singer-sdk">
   <img alt="Downloads" src="https://img.shields.io/pypi/dw/singer-sdk?label=Downloads&labelColor=471E80&color=110B1E"/>
  </a>
  </br>
  <a href="https://pypi.org/project/singer-sdk">
   <img alt="PyPI Version" src="https://img.shields.io/pypi/v/singer-sdk?label=PyPI%20Version&labelColor=471E80&color=110B1E"/>
  </a>
  <a href="https://sdk.meltano.com/en/latest">
   <img alt="Read the Docs (version)" src="https://img.shields.io/readthedocs/meltano-sdk/latest?label=Docs&labelColor=471E80&color=110B1E">
  </a>
  <a href="https://codecov.io/gh/meltano/sdk">
   <img alt="Codecov" src="https://img.shields.io/codecov/c/github/meltano/sdk?label=Coverage&labelColor=471E80&color=110B1E">
  </a>
  <a href="https://github.com/astral-sh/uv">
   <img alt="uv" src="https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/uv/main/assets/badge/v0.json&labelColor=471E80&color=110B1E"/>
  </a>
</div>

______________________________________________________________________

## Future-proof extractors and loaders, with less code

On average, developers tell us that they write about 70% less code by using the SDK, which
makes learning the SDK a great investment. Furthermore, as new features and capabilities
are added to the SDK, your taps and targets can always take advantage of the latest
capabilities and bug fixes, simply by updating your SDK dependency to the latest version.

## Meltano

_Not familiar with Meltano?_ [Meltano](https://docs.meltano.com/getting-started/meltano-at-a-glance) is your CLI for ELT+ that:

- **Starts simple**: Meltano is pip-installable and comes in a prepackaged docker container, you can have your first ELT pipeline running within minutes.
- **Has DataOps out-of-the-box**: Meltano provides tools that make DataOps best practices easy to use in every project.
- **Integrates with everything**: 300+ natively supported data sources & targets, as well as additional plugins like great expectations or dbt are natively available.
- **Is easily customizable**: Meltano isn't just extensible, it's built to be extended! The Singer SDK (for Connectors) & EDK (for Meltano Components) are easy to use. Meltano Hub helps you find all of the connectors and components created across the data community.
- **Is a mature system**: Developed since 2018, runs in production at large companies like GitLab, and currently powers over a million pipeline runs monthly.
- **Has first class ELT tooling built-in**: Extract data from any data source, load into any target, use inline maps to transform on data on the fly, and test the incoming data, all in one package.

If you want to get started with Meltano, we suggest you:

- head over to the [Installation](https://docs.meltano.com/getting-started/installation)
- or if you have it installed, go through the [Meltano Tutorial](https://docs.meltano.com/getting-started/part1).

## Documentation

- See our [online documentation](https://sdk.meltano.com) for instructions on how
  to get started with the SDK.

## Contributing back to the SDK

- For more information on how to contribute, see our [Contributors Guide](https://sdk.meltano.com/en/latest/CONTRIBUTING.html).

## Making a new release of the SDK

1. Trigger a version bump [using the GitHub web UI](https://github.com/edgarrmondragon/sdk/actions/workflows/version_bump.yml) or the cli:

   ```console
   $ gh workflow run
   ```

   The `increment: auto` option will figure out the most appropriate bump based on commit history.

1. Follow the checklist in the PR description.

1. Publish a new release [using the GitHub web UI](https://github.com/meltano/sdk/releases/new).
