Singer.io tap for extracting data
Project description
tap-ordway
This is a Singer tap that produces JSON-formatted data following the Singer spec.
This tap:
- Pulls raw data from OrdwayLabs
- Extracts the following resources:
- billing_runs
- billing_schedules
- charges
- chart_of_accounts
- contacts
- coupons
- credits
- customer_notes
- customers
- invoices
- orders
- payment_methods
- payment_runs
- payments
- plans
- products
- refunds
- revenue_rules
- revenue_schedules
- statements
- subscriptions
- usages
- webhooks
- Outputs the schema for each resource
- Incrementally pulls data based on the input state
Installation
Requirements
- Python 3.6+
- mkvirtualenv
- pip
Steps
Run following commands on terminal from the project directory
python3 -m venv ~/.virtualenvs/tap-ordway
source ~/.virtualenvs/tap-ordway/bin/activate
pip install -e .
To Run
$ source ~/.virtualenvs/tap-ordway/bin/activate
$ tap-ordway -c config.json --catalog catalog.json -s state.json
You can generate the catalog.json by following command:
$ tap-ordway -c config.json --discover > catalog.json
The sample config JSON is format is given below:
{
"company": "Rocky",
"user_email": "me@example.com",
"user_token": "123usertoken",
"api_key": "123secret",
"start_date": "2019-12-01"
}
The start_date
indicates the data at which the tap should start syncing data when no bookmark exists in the state for that particular stream.
The following configuration keys are optional:
staging
- Whether or not to use the staging environment (staging.ordwaylabs.com)api_version
- Which Ordwaylabs API version to use (e.g. "v1")api_url
- An alternative URL to which the API requests will be made (e.g. "https://localhost:3000/v1/"). When specified, it will take precendence overstaging
andapi_version
.rate_limit_rps
- The amount of requests to allow per second (defaults tonull
, disabling rate limiting)
The State JSON should be passed by user. The Tap will be printing the STATE message, the last state message should send when running next time.
Sample JSON:
{
"currently_syncing": "credits",
"bookmarks": {
"credits": {
"updated_date": "2020-11-14T05:59:48.842000Z"
}
}
}
Testing
- Install the dev extra requirements
pip install .[dev]
- Execute tox with the default environments:
py36
,py37
,py38
, andtype
(for static type checking via mypy)
tox
Additionally, you can generate a Coverage report by using the coverage
environment:
tox -e coverage
For more information on tox, please refer to its documentation.
Testing with singer-check-tap
singer-check-tap is a tool for testing whether or not a tap adheres to the Singer specification. For more information, please review its documentation.
- Install the singer-tools package
pip install singer-tools
- Execute singer-check-tap
singer-check-tap --tap tap-ordway --config config.json
In this mode, singer-check-tap will execute the tap itself, run it in discover mode to generate a catalog, perform a stateless run and a stateful run, and validate the tap's output.
If you need to test with a modified catalog, you can do so by piping the tap's output directly into singer-check-tap like so:
tap-ordway --config config.json --catalog catalog.json | singer-check-tap
Copyright © 2020 Stitch
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
File details
Details for the file tap-ordway-0.2.0.tar.gz
.
File metadata
- Download URL: tap-ordway-0.2.0.tar.gz
- Upload date:
- Size: 35.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.5.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a0fa45b1cf2e54189ac42d23886ab9a6bd9b86c609aac56547dd2e4d4cb46469 |
|
MD5 | 36d4009aaeeda9d631852c307d30f59f |
|
BLAKE2b-256 | 240a976c8466e588b8891636af4f9e60e9908e6d26762b44d49ea589b361a43a |