Python SDK for https://fragment.dev/
Project description
fragment-python
Fragment is the Ledger API for engineers that move money. Stop wrangling payment tables, debugging balance errors, and hacking together data pipelines. Start shipping the features that make a difference.
Installation
Using pip
:
pip install fragment-python
Using poetry
:
poetry add fragment-python
Usage
Get started by instantiating a Client
from fragment.sdk.client
. You can generate credentials using the Fragment dashboard
from fragment.sdk.client import Client
graphql_client = Client(
client_id="<client id from the dashboard>",
client_secret="<client secret from the dashboard>",
api_url="<api url from the dashboard>",
auth_url="<auth url from the dashboard>",
auth_scope="<auth scope from the dashboard>",
)
async def print_schema():
get_schema_result = await graphql_client.get_schema("<Your schema key here>")
print(get_schema_result.schema_.json())
import asyncio
loop = asyncio.get_event_loop()
loop.run_until_complete(print_schema())
Read the Using custom queries section to learn how to use your own GraphQL queries with the SDK.
Using a synchronous client
If you prefer using a synchronous client instead of an async one, then:
from fragment.sync_sdk.client import Client
graphql_client = Client(
client_id="<client id from the dashboard>",
client_secret="<client secret from the dashboard>",
api_url="<api url from the dashboard>",
auth_url="<auth url from the dashboard>",
auth_scope="<auth scope from the dashboard>",
)
get_schema_result = graphql_client.get_schema("<Your schema key here>")
print(get_schema_result.schema_.json())
Examples
Post a Ledger Entry
To post a Ledger Entry defined in your Schema:
await graphql_client.add_ledger_entry(
ik="some-ik",
ledger_ik="your-ledger-ik",
type="user_funds_account",
posted="1968-01-01T16:45:00Z",
parameters=dict(
user_id="user-1",
funding_amount="20000",
)
)
Read a Ledger Account's Balance
To read a Ledger Account's balance:
from fragment.sdk.enums import CurrencyCode
from fragment.sdk.input_types import CurrencyMatchInput
await graphql_client.get_ledger_account_balance(
ledger_ik="your-ledger-ik",
path="liabilities/user:user-1/available",
balance_currency=CurrencyMatchInput(code=CurrencyCode.USD),
)
Using custom queries
While the SDK comes with GraphQL queries out of the box, you may want to customize these queries for your product. In order to do that:
- Define your custom GraphQL queries in a GraphQL file. For example, in
queries/custom-queries.graphql
:
query getSchemaName($key: SafeString!) {
schema(schema: { key: $key }) {
key
name
}
}
- Run
fragment-python-client-codegen
to generate the GraphQL SDK client. GraphQL named queries are converted to snake_case to conform to Python's code conventions. Optionally, pass the--sync
flag to generate a synchronous client instead of the default async GraphQL client.
fragment-python-client-codegen \
--input-dir queries/ \
--target-package-name=custom_queries_package \
--output-dir=libs/fragment
- Use the client from the generated package in your product! Apart from the custom query methods, this client is functionally identical to
fragment.sdk.client.Client
from .libs.custom_queries_package.client import Client
graphql_client = Client(
client_id="<client id from the dashboard>",
client_secret="<client secret from the dashboard>",
api_url="<api url from the dashboard>",
auth_url="<auth url from the dashboard>",
auth_scope="<auth scope from the dashboard>",
)
async def print_schema_name():
# Note that getSchemaName is converted to snake_case automatically
response = await graphql_client.get_schema_name("<Your Schema Key>")
print(response.schema_.key)
import asyncio
loop = asyncio.get_event_loop()
loop.run_until_complete(print_schema())
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
Built Distribution
File details
Details for the file fragment_python-0.2.2.tar.gz
.
File metadata
- Download URL: fragment_python-0.2.2.tar.gz
- Upload date:
- Size: 40.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.14 Darwin/23.5.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4acf5e862100c14060f75157a0631098806d0b2fe16541d4dc2f201754d93e8b |
|
MD5 | 0e7077674e7fb06a425e7a2732df0fe9 |
|
BLAKE2b-256 | 302489103c7ee1a83bc42b7038228bcc5d46f0b290afc786d964d73c81427ee7 |
File details
Details for the file fragment_python-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: fragment_python-0.2.2-py3-none-any.whl
- Upload date:
- Size: 63.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.14 Darwin/23.5.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bff375a7f8968b2f421e9c38756caa59ad5e9d7d0a01034b259a8bc45c421dda |
|
MD5 | 4f561f38b0ffe64911e05d4f4f545193 |
|
BLAKE2b-256 | ebdf59a8134880b0b86fe00c9ae7ddf2d1ff60a254ddcdb7732c8183b0a0f87c |