Metadata-Version: 2.4
Name: ntlabs
Version: 1.0.1
Summary: Python SDK for Neural Thinkers LAB AI Platform - Sync and Async Support
Project-URL: Homepage, https://neural-lab-kappa.vercel.app
Project-URL: Documentation, https://neural-lab-kappa.vercel.app/docs
Project-URL: Repository, https://github.com/NeuralThinkersLab/neural-lab
Author-email: Anderson Henrique da Silva <andersonhs27@gmail.com>
License: Proprietary - Neural Thinker | AI Engineering LTDA
License-File: LICENSE
Keywords: ai,api,claude,hipocrates,llm,maritaca,mercurius,neural-thinkers,ntlabs,polis
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: Other/Proprietary License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Requires-Python: >=3.10
Requires-Dist: httpx>=0.25.0
Provides-Extra: dev
Requires-Dist: pytest-asyncio>=0.21.0; extra == 'dev'
Requires-Dist: pytest>=7.0.0; extra == 'dev'
Requires-Dist: ruff>=0.1.0; extra == 'dev'
Description-Content-Type: text/markdown

# Neural LAB Python SDK

**PROPRIETARY SOFTWARE - ALL RIGHTS RESERVED**

Python SDK for Neural LAB AI Platform APIs.

## Proprietary Notice

```
Copyright (c) 2026 Neural Thinker | AI Engineering LTDA
CNPJ: 62.155.930/0001-71
Author: Anderson Henrique da Silva
Location: Minas Gerais, Brasil

This software is proprietary and confidential.
Unauthorized copying, distribution, or use is strictly prohibited.
```

## Installation

This SDK is **private** and not published to PyPI.

### For Neural LAB Products (Hipócrates, Mercurius, Polis)

In `requirements.txt`:

```txt
neural-lab @ git+https://github.com/anderson-ufrj/neural-lab.git#subdirectory=packages/python-sdk
```

### Local Development

```bash
pip install -e /path/to/neural-lab/packages/python-sdk
```

## Quick Start

```python
from neural_lab import NeuralLabClient

# Initialize client
client = NeuralLabClient(api_key="nl_hipo_xxx")

# Or use environment variable NEURAL_LAB_API_KEY
client = NeuralLabClient()
```

## Available Resources

### Chat (LLM)

```python
response = client.chat.complete(
    messages=[
        {"role": "system", "content": "Você é um assistente médico."},
        {"role": "user", "content": "O que é hipertensão?"}
    ],
    model="maritaca-sabia-3",
    max_tokens=1024,
)
```

### Email

```python
client.email.send(
    to=["paciente@email.com"],
    subject="Confirmação de Consulta",
    html="<h1>Sua consulta foi agendada</h1>",
)
```

### Transcription

```python
result = client.transcribe.audio("consulta.mp3", language="pt")
print(result.text)
```

### Government APIs

```python
# CNPJ lookup
empresa = client.gov.cnpj("12.345.678/0001-90")

# CEP lookup
endereco = client.gov.cep("01310-100")

# CPF validation
valido = client.gov.validate_cpf("123.456.789-00")

# Portal da Transparência
contratos = client.gov.transparencia("contratos", params={"uf": "MG"})
```

### Banco do Brasil (OAuth + PIX)

```python
from decimal import Decimal

# OAuth - Get authorization URL
auth = client.bb.get_authorize_url(redirect_uri="https://app.com/callback")
# Redirect user to auth.authorize_url

# OAuth - Exchange code for tokens
tokens = client.bb.exchange_code(code="abc", state="xyz", redirect_uri="...")

# Get user info (CPF verified by bank)
user = client.bb.get_userinfo(tokens.access_token)
print(f"CPF: {user.cpf}, Nome: {user.nome}")

# PIX - Create charge
charge = client.bb.create_pix_charge(
    amount=Decimal("99.90"),
    description="Consulta Médica",
)
print(f"QR Code: {charge.qr_code}")

# PIX - Check status
status = client.bb.get_pix_status(charge.txid)
if status.status == "CONCLUIDA":
    print(f"Pago em: {status.paid_at}")
```

### Medical AI (Hipócrates)

```python
# Transcribe consultation
transcription = client.saude.transcribe(audio_file)

# Generate SOAP note
soap = client.saude.generate_soap(
    transcription=transcription.text,
    paciente={"idade": 45, "sexo": "M"},
)
```

### Notary AI (Mercurius)

```python
# OCR certificate
result = client.cartorio.ocr(image_file, tipo="nascimento")

# Generate deed
minuta = client.cartorio.generate_escritura(dados)
```

### Billing

```python
usage = client.billing.get_usage()
print(f"Total: R$ {usage.total_cost}")
```

## Environment Variables

| Variable | Description |
|----------|-------------|
| `NEURAL_LAB_API_KEY` | API key (nl_hipo_xxx, nl_merc_xxx, nl_poli_xxx) |
| `NEURAL_LAB_API_URL` | API URL (default: production) |

## Error Handling

```python
from neural_lab import (
    NeuralLabClient,
    AuthenticationError,
    RateLimitError,
    InsufficientCreditsError,
    APIError,
)

try:
    response = client.chat.complete(messages=[...])
except AuthenticationError:
    print("Invalid API key")
except RateLimitError as e:
    print(f"Rate limited. Retry after {e.retry_after}s")
except InsufficientCreditsError:
    print("Add more credits")
except APIError as e:
    print(f"API error: {e}")
```

## License

**Proprietary Software**

Copyright (c) 2026 Neural Thinker | AI Engineering LTDA

All rights reserved. This software and its documentation are proprietary
and confidential. No part of this software may be reproduced, distributed,
or transmitted in any form or by any means without the prior written
permission of Neural Thinker | AI Engineering LTDA.

For licensing inquiries: contato@neural-lab.com.br
