Skip to main content

Zenmoney API client

Project description

ZenMoney API Client

A Python client for the ZenMoney API with proper OAuth2 authentication support.

Installation

pip install zenmoney-api

Usage

OAuth2 Authentication

The client supports OAuth2 authentication as described in the ZenMoney API documentation.

Step 1: Create Authorization URL

import asyncio
from zenmoney_api.auth import AsyncZenMoneyOAuth2Client

async def get_authorization_url():
    # Create OAuth2 client
    client = AsyncZenMoneyOAuth2Client(
        client_id="your_client_id",
        client_secret="your_client_secret",
        redirect_uri="http://your-app.com/callback"
    )

    # Generate authorization URL
    auth_url = client.authorization_url()
    print(f"Authorization URL: {auth_url}")

    return client

# Run the function
client = asyncio.run(get_authorization_url())

Step 2: Exchange Authorization Code for Token

import asyncio
from zenmoney_api.auth import AsyncZenMoneyOAuth2Client

async def exchange_code_for_token():
    # Use the client from step 1
    client = AsyncZenMoneyOAuth2Client(
        client_id="your_client_id",
        client_secret="your_client_secret",
        redirect_uri="http://your-app.com/callback"
    )

    # Exchange authorization code for access token
    code = "authorization_code_from_callback"
    token = await client.fetch_token(code=code)

    print(f"Access Token: {token['access_token']}")
    print(f"Refresh Token: {token['refresh_token']}")

    return token

# Run the function
token = asyncio.run(exchange_code_for_token())

Step 3: Use the API with Token

import asyncio
from zenmoney_api.client import ZenMoneyClient

async def use_api():
    # Create client with existing token
    client = ZenMoneyClient.create_with_token(
        client_id="your_client_id",
        client_secret="your_client_secret",
        token=token  # from step 2
    )

    # Get data from ZenMoney API
    diff_data = await client.get_diff()
    print(f"Diff data: {diff_data}")

    # Get suggestions for transaction
    suggestion = await client.suggest({"payee": "McDonalds"})
    print(f"Suggestion: {suggestion}")

# Run the function
asyncio.run(use_api())

Complete Example

Here's a complete example showing the full OAuth2 flow:

import asyncio
from zenmoney_api.auth import AsyncZenMoneyOAuth2Client
from zenmoney_api.client import ZenMoneyClient

async def complete_oauth2_flow():
    # Step 1: Create OAuth2 client
    auth_client = AsyncZenMoneyOAuth2Client(
        client_id="your_client_id",
        client_secret="your_client_secret",
        redirect_uri="http://your-app.com/callback"
    )

    # Generate authorization URL
    auth_url = auth_client.authorization_url()
    print(f"Please visit: {auth_url}")

    # Step 2: After user authorizes, you'll get the code in your callback
    # This is just an example - in real app, you'd get this from your web server
    code = "authorization_code_from_callback"

    # Exchange code for token
    token = await auth_client.fetch_token(code=code)

    # Step 3: Create API client with token
    api_client = ZenMoneyClient(auth_client)

    # Use the API
    diff_data = await api_client.get_diff()
    print(f"Diff data: {diff_data}")

    # Get suggestions
    suggestion = await api_client.suggest({"payee": "McDonalds"})
    print(f"Suggestion: {suggestion}")

# Run the complete flow
asyncio.run(complete_oauth2_flow())

Token Refresh

The client automatically handles token refresh when needed. You can also manually refresh a token:

import asyncio
from zenmoney_api.auth import AsyncZenMoneyOAuth2Client

async def refresh_token():
    client = AsyncZenMoneyOAuth2Client(
        client_id="your_client_id",
        client_secret="your_client_secret"
    )

    # Refresh token
    new_token = await client.refresh_token()
    print(f"New access token: {new_token['access_token']}")

# Run the function
asyncio.run(refresh_token())

API Endpoints

Diff Endpoint

Synchronize data with ZenMoney:

# Get all data
diff_data = await client.get_diff()

# Send local changes
local_changes = {
    "currentClientTimestamp": 1234567890,
    "transaction": [
        {
            "id": "transaction-uuid",
            "changed": 1234567890,
            "user": 1,
            "income": 1000,
            "outcome": 0,
            # ... other transaction fields
        }
    ]
}
diff_response = await client.get_diff(local_changes)

Suggest Endpoint

Get suggestions for transaction categorization:

# Single transaction
suggestion = await client.suggest({
    "payee": "McDonalds"
})

# Multiple transactions
suggestions = await client.suggest([
    {"payee": "McDonalds"},
    {"payee": "Starbucks"}
])

Data Models

The library includes Pydantic models for all ZenMoney entities:

  • Instrument - Currency information
  • Company - Bank or payment organization
  • User - User information
  • Account - User accounts
  • Tag - Transaction categories
  • Merchant - Payees
  • Reminder - Scheduled transactions
  • ReminderMarker - Reminder instances
  • Transaction - Financial transactions
  • Budget - Budget information

Development

Setup

# Clone the repository
git clone https://github.com/your-username/zenmoney-api.git
cd zenmoney-api

# Install dependencies
uv sync --all-groups

Running Tests

# Run all tests
uv run pytest

# Run with coverage
uv run pytest --cov=src/zenmoney_api

# Run ruff linting
uv run ruff check src/

# Run pylint linting
uv run pylint src/

# Run type checking
uv run mypy src/

Also you can run all them just by running pre-commit tool:

uv run pre-commit --all-files

You can install pre-commit hooks to run on every commit:

uv run pre-commit install

License

MIT License - see LICENSE file for details.

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

zenmoney_api-0.1.0a2.tar.gz (54.5 kB view details)

Uploaded Source

Built Distribution

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

zenmoney_api-0.1.0a2-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

Details for the file zenmoney_api-0.1.0a2.tar.gz.

File metadata

  • Download URL: zenmoney_api-0.1.0a2.tar.gz
  • Upload date:
  • Size: 54.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for zenmoney_api-0.1.0a2.tar.gz
Algorithm Hash digest
SHA256 df8fc46f0a45f818c49bc3f87e7b0412dd6ca8d448e9500781f18ba9184c65f8
MD5 907eedefdfbb343a15c7336e557ac290
BLAKE2b-256 4660a2c2cae501c389243617765d597ea4f583f76737b47b824dad409e047e73

See more details on using hashes here.

Provenance

The following attestation bundles were made for zenmoney_api-0.1.0a2.tar.gz:

Publisher: python-publish.yml on sakost/zenmoney-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file zenmoney_api-0.1.0a2-py3-none-any.whl.

File metadata

  • Download URL: zenmoney_api-0.1.0a2-py3-none-any.whl
  • Upload date:
  • Size: 8.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for zenmoney_api-0.1.0a2-py3-none-any.whl
Algorithm Hash digest
SHA256 354db93c19505d87900f3b6b832239f00a38ced0b7053733d05d996b388a53fb
MD5 b5b63982524d53372f2ab9bd17c99fdc
BLAKE2b-256 4e4c9b5074ce47f95704dae1b36bfc905f0f66a5f5574659d2efd5a27c79c05a

See more details on using hashes here.

Provenance

The following attestation bundles were made for zenmoney_api-0.1.0a2-py3-none-any.whl:

Publisher: python-publish.yml on sakost/zenmoney-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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