Skip to main content

A set of tools for connecting and processing data for Annex Brands, featuring API pack and ship quoting.

Project description

ABConnect

Documentation Status PyPI version Python Support

ABConnect is a Python package that provides a collection of tools for connecting and processing data for Annex Brands. It includes modules for quoting, building, and loading data from various file formats (CSV, JSON, XLSX), with a focus on handling unsupported characters and encoding issues seamlessly.

Table of Contents

Features

New in v0.1.8

  • Generic Endpoint System: Automatic access to all 223+ API endpoints without manual implementation
  • Fluent Query Builder: Build complex API queries with method chaining
  • Pydantic Models: Type-safe response models with automatic validation

Core Features

  • API Request Builder: Assemble dynamic API requests using static JSON templates and runtime updates.
  • Quoter Module: Retrieve and parse quotes from the ABC API in both Quick Quote (qq) and Quote Request (qr) modes.
  • Robust Data Loading: Supports CSV, JSON, and XLSX files with built-in encoding and character handling.
  • Full API Client: Comprehensive API client with authentication and endpoint-specific methods.

Installation

You can install ABConnect using pip:

pip install ABConnect

For more detailed installation instructions and documentation, visit https://abconnecttools.readthedocs.io/

Configuration

Environment Variables

ABConnect requires the following environment variables for authentication:

# Create a .env file with your credentials
ABCONNECT_USERNAME=your_username
ABCONNECT_PASSWORD=your_password
ABC_CLIENT_ID=your_client_id
ABC_CLIENT_SECRET=your_client_secret

# Optional: Set environment (defaults to production)
ABC_ENVIRONMENT=staging  # or 'production'

Using Different Environments

ABConnect supports both staging and production environments:

from ABConnect.api import ABConnectAPI

# Use staging environment
api = ABConnectAPI(env='staging')

# Use production environment (default)
api = ABConnectAPI()

# Environment can also be set via ABC_ENVIRONMENT variable

Testing Configuration

For testing, create a .env.staging file with staging credentials:

cp ABConnect/dotenv.sample .env.staging
# Edit .env.staging with your staging credentials

Tests will automatically use .env.staging when running with pytest.

Documentation

Full documentation is available at https://abconnecttools.readthedocs.io/

Development

To contribute to ABConnect, clone the repository and install in development mode:

git clone https://github.com/AnnexBrands/ABConnectTools.git
cd ABConnectTools
pip install -e .[dev]

Testing

Run all tests with:

pytest

Testing Model Implementation Against Swagger

ABConnect maintains strict alignment with the API's swagger specification. Several tests verify that all models and endpoints are properly implemented:

1. Test All Endpoints Have Implementations

# Comprehensive test with visual tree output showing which endpoints are implemented
pytest tests/api/swagger/test_all_swagger_endpoints_have_implementations.py -v

# Displays:
# ✅ Working endpoints with path count
# ❌ Missing endpoint files
# ⚠️  Import failures for endpoints that exist but can't be imported

2. Test Constitution Compliance

# Tests endpoint-model pairing and swagger-first principles
pytest tests/test_constitution.py -v

# Verifies:
# - All swagger endpoints have implementations
# - Endpoints have corresponding Pydantic models
# - No duplicate or violating files exist

3. Verify Model Imports

# Test that all models can be imported without errors
python -c "from ABConnect.api.models import shared, companies, contacts, job, address, jobtimeline; print('All model imports successful')"

# Test specific model validation and inspect fields
python -c "from ABConnect.api.models.jobparcelitems import ParcelItem; print(list(ParcelItem.model_fields.keys()))"

4. Run Specific Test Categories

# Test only API endpoints
pytest tests/api/ -v

# Test only models
pytest tests/api/models/ -v

# Test swagger compliance with detailed output
pytest tests/api/swagger/ -v -s

Test Coverage Summary

  • Endpoint Tests: Verify all 223+ API endpoints are accessible
  • Model Tests: Validate Pydantic models match swagger schemas
  • Integration Tests: Test end-to-end API workflows
  • Constitution Tests: Ensure code follows architecture principles

License

This project is licensed under the MIT License - see the LICENSE file for details.

Links

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

abconnect-0.2.0.tar.gz (197.1 kB view details)

Uploaded Source

Built Distribution

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

abconnect-0.2.0-py3-none-any.whl (272.7 kB view details)

Uploaded Python 3

File details

Details for the file abconnect-0.2.0.tar.gz.

File metadata

  • Download URL: abconnect-0.2.0.tar.gz
  • Upload date:
  • Size: 197.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for abconnect-0.2.0.tar.gz
Algorithm Hash digest
SHA256 27705c0abda5f85f012facb295a1d24d3bfefee6e3f444309ac0d84854d5ff83
MD5 9ab77a3f69b1ee8fc3a053a210576d67
BLAKE2b-256 ef1081a2820b06bf8ed927a2a7cc149840c997f7ff1bc5c53cf66c908f41335c

See more details on using hashes here.

Provenance

The following attestation bundles were made for abconnect-0.2.0.tar.gz:

Publisher: workflow.yml on AnnexBrands/ABConnectTools

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

File details

Details for the file abconnect-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: abconnect-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 272.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for abconnect-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 40ce241b3dac41a2812cacfb20cfc584c38aaccbc6691849c3b7d273307b8b5d
MD5 790da307e96df3e4717c40ebcad60797
BLAKE2b-256 dff00d705d39c3d71b1a93bad94482a0a5b52143be95bdf30d1a8091d6ccef5a

See more details on using hashes here.

Provenance

The following attestation bundles were made for abconnect-0.2.0-py3-none-any.whl:

Publisher: workflow.yml on AnnexBrands/ABConnectTools

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