Skip to main content

Unofficial Python SDK for Loops.so email platform

Project description

PyLoops

Unofficial Python SDK for Loops.so.

PyPI version Python 3.12+

Installation

pip install pyloops

Or with uv:

uv add pyloops

Quick Start

PyLoops offers two ways to interact with the Loops API:

High-Level API

import pyloops

# Configure once (or set LOOPS_API_KEY environment variable)
pyloops.configure(api_key="your_api_key_here")

# Get the client
client = pyloops.get_client()

# Upsert a contact
await client.upsert_contact(
    email="user@example.com",
    first_name="John",
    last_name="Doe",
    subscribed=True,
)

# Find a contact
contacts = await client.find_contact(email="user@example.com")

# Send an event
await client.send_event(
    event_name="user_signup",
    email="user@example.com",
    event_properties={"plan": "premium"},
)

# List mailing lists
mailing_lists = await client.list_mailing_lists()

Low-Level API

For more control, use the auto-generated low-level API directly:

from pyloops import AuthenticatedClient
from pyloops.api.contacts import put_contacts_update
from pyloops.models import ContactUpdateRequest

client = AuthenticatedClient(
    base_url="https://app.loops.so/api/v1",
    token="your_api_key_here",
)

response = await put_contacts_update.asyncio(
    client=client,
    body=ContactUpdateRequest(
        email="user@example.com",
        first_name="John",
        last_name="Doe"
    )
)

Authentication

All API calls require a Loops API key. Get your API key from your Loops account settings.

There are three ways to configure authentication:

  1. Environment variable:
export LOOPS_API_KEY="your_api_key_here"
  1. Module-level configuration:
import pyloops
pyloops.configure(api_key="your_api_key_here")
  1. Per-client configuration:
import pyloops
client = pyloops.LoopsClient(api_key="your_api_key_here")

Features

This SDK provides access to all Loops.so API endpoints:

  • Contacts: Create, update, find, and delete contacts
  • Contact Properties: Manage custom contact properties
  • Mailing Lists: View available mailing lists
  • Events: Trigger event-based emails
  • Transactional Emails: Send and list transactional emails
  • Sending IPs: Retrieve dedicated sending IP addresses

Documentation

For detailed API documentation, visit the Loops.so API docs.

Automated Updates

This SDK is automatically updated to match the latest Loops.so API specification. The package version corresponds to the Loops API version (current: 1.7.0).

A GitHub Action checks for API updates daily and creates a pull request when changes are detected. After review and merge, a new version is automatically published to PyPI.

Development

Setup

# Clone the repository
git clone https://github.com/doctorgpt-corp/pyloops.git
cd pyloops

# Install dependencies with uv
uv sync --all-groups

Running Tests

Using just:

just check      # Run linting + type checking
just lint       # Run linting only
just typecheck  # Run type checking only
just fmt        # Format code

Or directly with uv:

uv run ruff check src/
uv run pyright src/

Project Structure

src/pyloops/
├── __init__.py          # Main exports
├── client.py            # High-level LoopsClient wrapper
├── config.py            # Configuration
├── exceptions.py        # Exceptions
├── api/                 # Re-exports from _generated.api
├── models/              # Re-exports from _generated.models
└── _generated/          # ALL auto-generated code
    ├── client.py
    ├── api/
    ├── models/
    └── types.py

Regenerate SDK

To manually regenerate the SDK from the latest OpenAPI spec:

just generate

Or manually:

rm -rf src/pyloops/_generated
uv tool run openapi-python-client generate --url https://app.loops.so/openapi.yaml --meta uv
mv loops-open-api-spec-client/loops_open_api_spec_client src/pyloops/_generated
rm -rf loops-open-api-spec-client openapi.yaml

Custom code is never touched during regeneration.

License

MIT

Disclaimer

This is an unofficial SDK and is not affiliated with or endorsed by Loops.so.

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

pyloops-1.7.0.tar.gz (22.6 kB view details)

Uploaded Source

Built Distribution

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

pyloops-1.7.0-py3-none-any.whl (66.5 kB view details)

Uploaded Python 3

File details

Details for the file pyloops-1.7.0.tar.gz.

File metadata

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

File hashes

Hashes for pyloops-1.7.0.tar.gz
Algorithm Hash digest
SHA256 388eead942aa86daa97d441b7e1894b369b01c209372d03ef930483b811f664d
MD5 cb56ad4529094e9ffc925e67b077e464
BLAKE2b-256 5bb213b8ede165a37f000c952c4fd1752d5af9c32e323c8e21e1223bef416570

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyloops-1.7.0.tar.gz:

Publisher: publish.yml on doctorgpt-corp/pyloops

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

File details

Details for the file pyloops-1.7.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for pyloops-1.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a934c49b452ef33646f8b3af777f70027f336d85303d1e96d36d3b7bb7799293
MD5 f70ac8fee535f20909a1abce29f88a6d
BLAKE2b-256 2611b881cfa40b8526702feb4465eb5324691986eb77bee1d1d4a26f81c2f2bc

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyloops-1.7.0-py3-none-any.whl:

Publisher: publish.yml on doctorgpt-corp/pyloops

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