Skip to main content

A framework for building Singer taps and targets

Project description

Hotglue SDK for Taps

This is a fork of Melanto's SingerSDK for special use in hotglue, an embedded integration platform for running Singer Taps and Targets.

Taps and targets built on the SDK are automatically compliant with the Singer Spec, the de-facto open source standard for extract and load pipelines.

OAuth Access Token Support

Taps can implement the --access-token CLI flag to refresh OAuth access tokens without running the tap directly.

Implementing Access Token Support

To enable this feature in your tap, override the access_token_support class method to return a tuple of (authenticator_class, auth_endpoint):

from hotglue_singer_sdk import Tap
from my_tap.auth import MyOAuthAuthenticator

class MyTap(Tap):
    name = "tap-myservice"

    @classmethod
    def access_token_support(cls, connector=None):
        """Return the authenticator class and auth endpoint for token refresh.

        Returns:
            A tuple of (authenticator_class, auth_endpoint).
        """
        default_url = "https://api.myservice.com/oauth/token"
        # ommit if token url is not dynamic
        dynamic_url = connector.config.get("auth_url")
        url = dynamic_url or default_url
        return (MyOAuthAuthenticator, url)

Authenticator Requirements

The authenticator class must implement the following methods:

  • is_token_valid() - Returns True if the current access token is still valid
  • update_access_token() - Refreshes the access token and updates the config file

The authenticator will be instantiated with these parameters:

  • stream - A dummy stream object with logger, tap_name, and config attributes
  • config_file - Path to the config file for writing updated tokens
  • auth_endpoint - The OAuth token endpoint URL

Usage

Once implemented, users can refresh the access token using:

tap-myservice --config config.json --access-token

This will output the new access token as JSON:

{
  "access_token": "new_token_value"
}

Note: The --access-token flag requires a config file path. It will not work with --config ENV or when omitting the config.

Project details


Download files

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

Source Distribution

hotglue_singer_sdk-1.0.34.tar.gz (109.8 kB view details)

Uploaded Source

Built Distribution

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

hotglue_singer_sdk-1.0.34-py3-none-any.whl (136.8 kB view details)

Uploaded Python 3

File details

Details for the file hotglue_singer_sdk-1.0.34.tar.gz.

File metadata

  • Download URL: hotglue_singer_sdk-1.0.34.tar.gz
  • Upload date:
  • Size: 109.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for hotglue_singer_sdk-1.0.34.tar.gz
Algorithm Hash digest
SHA256 4a8ac841b7e2e77ce1c78b3040b2a48e155bc9ddefbce6e26ec710718a2c3f3c
MD5 0a422160e52830c09fca670638ae0a7f
BLAKE2b-256 1fa0b84b3bbdcbf53a8d72bbdb0e1b0deebdf20e8318e785a0fee73305268de8

See more details on using hashes here.

File details

Details for the file hotglue_singer_sdk-1.0.34-py3-none-any.whl.

File metadata

File hashes

Hashes for hotglue_singer_sdk-1.0.34-py3-none-any.whl
Algorithm Hash digest
SHA256 05d09d301ddbcb3358da4a8f38e42a38b0caeb08ebb55524ac2d8e0f952235d5
MD5 86fcd8e36564550e6dad733c46ca7072
BLAKE2b-256 04cdb4cc3c3422d0f5d6fe707356fb40d6c6c956ed3dd38ac2fae690d9892836

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