Skip to main content

Async Python client library for the Valentina Noir API

Project description

Valentina Python Client

Async and sync Python client library for accessing the Valentina Noir API.

Features

  • Async and sync clients - Both VClient (async) and SyncVClient (sync) built on httpx
  • Type-safe - Full type hints with Pydantic models for request/response validation
  • Convenient factory pattern - Create a client once, access services from anywhere
  • Automatic pagination - Stream through large datasets with iter_all() or fetch everything with list_all()
  • Robust error handling - Specific exception types for different error conditions
  • Idempotency support - Optional automatic idempotency keys for safe retries
  • Rate limit handling - Built-in support for automatic rate limit retries

This client is a supported and up-to-date reference implementation for the Valentina Noir API.

Documentation

The full documentation is available at https://natelandau.github.io/valentina-python-client/.

Claude Code Skill

This repo includes a Claude Code skill that gives Claude deep knowledge of vclient's services, models, constants, and testing utilities. Install it so Claude can help you build applications against the Valentina API.

Install

claude install-skill /path/to/valentina-python-client/vclient-guide-skill

Once installed, Claude will automatically activate the skill when you're working with vclient imports, Valentina API endpoints, or FakeVClient testing.

Development Tools

Validate Constants

Verify that the Literal type constants in this package are in sync with the live API's /options endpoint. This catches drift between client and server before a release.

# Via duty task
uv run duty validate_constants

# Via script directly
uv run python scripts/validate_constants.py --api-key <key> --company-id <id>

The script reads configuration from (highest precedence first):

  1. CLI arguments (--api-url, --api-key, --company-id)
  2. System environment variables (VALENTINA_CLIENT_BASE_URL, VALENTINA_CLIENT_API_KEY, VALENTINA_CLIENT_DEFAULT_COMPANY_ID)
  3. A .env.secret file in the project root

Exit codes: 0 = all constants match, 1 = mismatches found, 2 = missing configuration.

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

valentina_python_client-1.22.1.tar.gz (107.8 kB view details)

Uploaded Source

Built Distribution

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

valentina_python_client-1.22.1-py3-none-any.whl (162.5 kB view details)

Uploaded Python 3

File details

Details for the file valentina_python_client-1.22.1.tar.gz.

File metadata

  • Download URL: valentina_python_client-1.22.1.tar.gz
  • Upload date:
  • Size: 107.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for valentina_python_client-1.22.1.tar.gz
Algorithm Hash digest
SHA256 042c1e8142fda90e69e46b9a17249a66a500d021dddcfeb73699969b37dc97f3
MD5 b9116e9659e7c60b93f3bf695cdab6c7
BLAKE2b-256 5b91cafef1b1c621c922c90ccd989f35ae3aece2d926f0f359a3f7d1444a235e

See more details on using hashes here.

File details

Details for the file valentina_python_client-1.22.1-py3-none-any.whl.

File metadata

File hashes

Hashes for valentina_python_client-1.22.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a5a3502c2ed038fb6dc7fb8a07a20ff6e7a6c3036634cf7b2023fa8ee519d3ec
MD5 13440a0bc09ea5d43e945b4d1c431aa6
BLAKE2b-256 45a2816a5447bc87bfe2f7b229c2e76d33db29ae2d176598aec4061c637c32b4

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