Skip to main content

A client library for accessing Field Manager Data API

Project description

field-manager-python-client

A client library for accessing Field Manager Data API

🚀 Quick Start

Installation

pip install field_manager_python_client python-keycloak

Authentication

The easiest way to get started is using the built-in authentication functions:

from field_manager_python_client import get_prod_client

# Authenticate with your Field Manager account
client = get_prod_client(email="your.email@example.com")

Basic Usage

from field_manager_python_client.api.projects import get_project_projects_project_id_get

# Use the authenticated client
project_info = get_project_projects_project_id_get.sync(
    client=client, 
    project_id="your-project-id"
)
print(f"Project: {project_info.name}")

🔐 Authentication Options

1. Integrated Authentication (Recommended)

from field_manager_python_client import authenticate

client = authenticate(environment="prod", email="user@example.com")

2. Manual Token Setup

from field_manager_python_client import AuthenticatedClient

client = AuthenticatedClient(
    base_url="https://app.fieldmanager.io/api/location", 
    token="your-access-token"
)

3. Service Account (for automation)

See the main repository for service account setup.

📖 API Usage Patterns

Synchronous Operations

from field_manager_python_client.api.organizations import get_organizations_organizations_get

# Simple request - returns data or None
organizations = get_organizations_organizations_get.sync(client=client)

# Detailed request - returns Response object with status code, headers, etc.
from field_manager_python_client.types import Response
response: Response = get_organizations_organizations_get.sync_detailed(client=client)
if response.status_code == 200:
    organizations = response.parsed

Asynchronous Operations

import asyncio
from field_manager_python_client.api.organizations import get_organizations_organizations_get

async def fetch_organizations():
    # Simple async request
    organizations = await get_organizations_organizations_get.asyncio(client=client)
    
    # Detailed async request
    response = await get_organizations_organizations_get.asyncio_detailed(client=client)
    return response.parsed

# Run async function
organizations = asyncio.run(fetch_organizations())

🛠️ Advanced Features

SSL Configuration

from field_manager_python_client import AuthenticatedClient

# Custom certificate bundle
client = AuthenticatedClient(
    base_url="https://internal.example.com/api", 
    token="token",
    verify_ssl="/path/to/certificate_bundle.pem"
)

# Disable SSL verification (not recommended for production)
client = AuthenticatedClient(
    base_url="https://internal.example.com/api", 
    token="token",
    verify_ssl=False
)

Custom HTTP Configuration

from field_manager_python_client import AuthenticatedClient

def log_request(request):
    print(f"Request: {request.method} {request.url}")

def log_response(response):
    print(f"Response: {response.status_code}")

client = AuthenticatedClient(
    base_url="https://api.example.com",
    token="token",
    httpx_args={"event_hooks": {"request": [log_request], "response": [log_response]}}
)

📚 Learn More

For comprehensive documentation, examples, and contribution guidelines, visit the main repository: https://github.com/norwegian-geotechnical-institute/field-manager-python-client

The repository includes:

  • 📖 Complete authentication guide
  • 🔧 Advanced usage examples
  • 🚀 Real-world code samples
  • 🤝 Contributing guidelines
  • 📋 Issue tracking and support

🔍 API Reference

Every endpoint becomes a Python function with four variants:

  • sync: Blocking request returning parsed data or None
  • sync_detailed: Blocking request returning full Response object
  • asyncio: Async version of sync
  • asyncio_detailed: Async version of sync_detailed

All path/query parameters and request bodies become function arguments. Functions are organized by API tags in field_manager_python_client.api.* modules.

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

field_manager_python_client-4.6.89.tar.gz (196.5 kB view details)

Uploaded Source

Built Distribution

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

field_manager_python_client-4.6.89-py3-none-any.whl (635.4 kB view details)

Uploaded Python 3

File details

Details for the file field_manager_python_client-4.6.89.tar.gz.

File metadata

  • Download URL: field_manager_python_client-4.6.89.tar.gz
  • Upload date:
  • Size: 196.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.12 Linux/6.11.0-1018-azure

File hashes

Hashes for field_manager_python_client-4.6.89.tar.gz
Algorithm Hash digest
SHA256 9d39d8cea91d747e38df63b911f6da980e3ca7b7d12c2e1ce9c75e9b25e4d7c2
MD5 64f507df21933d2b6fb34b72dee3156c
BLAKE2b-256 8af8efe9777e8947f68c476629fe3c2e4fc27b17c06b7dcde0672cd1ff17a180

See more details on using hashes here.

File details

Details for the file field_manager_python_client-4.6.89-py3-none-any.whl.

File metadata

File hashes

Hashes for field_manager_python_client-4.6.89-py3-none-any.whl
Algorithm Hash digest
SHA256 9b8d81b21aec9951b68bbdaed0aa0db61643c674c1b8bf4d09977a4d95b862f8
MD5 cfbef16c8e164bd4b24ade71f36a33cd
BLAKE2b-256 d469e8548e7fe9f263dcc5a6e74d9286b01ba4ff817ae661451a3deb90582406

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