Skip to main content

A Python client for Turso/libsql HTTP API with sync and async support

Project description

TursoPy

Alt text

A lightweight, dependency-minimal Python client for Turso databases. Born out of frustration with dependency issues in existing solutions, TursoPy provides a straightforward way to interact with Turso databases without the complexity.

Note: This project isn't meant to compete with libsql-experimental or suggest it's any better or worse. It's simply an alternative born from experiencing dependency issues with existing solutions. While TursoPy might not be as feature-rich as libsql-experimental, it gets the job done with minimal fuss. As a solo developer without corporate backing, I created this to solve my own frustrations and share it with others who might face similar challenges.

Features

  • Simple CRUD operations
  • Batch processing support
  • Advanced query capabilities including JOINs
  • Minimal dependencies (HTTP client via requests for sync and aiohttp for async)
  • Straightforward error handling
  • Database creation utilities

Installation

pip install turso-python

Using uv (recommended for local dev):
- Production deps only:
  uv pip install -e .
- With dev extras (tests, linting):
  uv pip install -e .[dev]

If pip install doesn't work, clone the project or download the zip from the realease section

Quick Start

  1. Set up your environment variables (or pass explicitly to the client). Do not commit secrets.
  • On Linux/macOS:

    export TURSO_DATABASE_URL="libsql://your_database_url"
    export TURSO_AUTH_TOKEN={{TURSO_AUTH_TOKEN}}
    
  • On Windows (PowerShell):

    setx TURSO_DATABASE_URL "libsql://your_database_url"
    setx TURSO_AUTH_TOKEN "{{TURSO_AUTH_TOKEN}}"
    

Note: The client accepts libsql:// and normalizes it to https:// automatically for HTTP calls.

  1. Basic usage:
from turso_python.connection import TursoConnection
from turso_python.crud import TursoCRUD

# Initialize connection (env vars or pass explicit values)
connection = TursoConnection()
crud = TursoCRUD(connection)

# Insert data
data = {"name": "John Doe", "age": 30}
crud.create("users", data)

# Read data
result = crud.read("users", "name = ?", ["John Doe"])

Detailed Usage Guide

Connection Management

The TursoConnection class handles all communication with the Turso API:

from turso_python.connection import TursoConnection

# Using environment variables
connection = TursoConnection()

# Or explicit credentials
connection = TursoConnection(
    database_url="your_database_url",
    auth_token="your_auth_token"
)

CRUD Operations

Create

crud = TursoCRUD(connection)

# Single insert
user_data = {
    "name": "Jane Smith",
    "email": "jane@example.com",
    "age": 25
}
crud.create("users", user_data)

Read

# Fetch all records
all_users = crud.read("users")

# Fetch with conditions
young_users = crud.read(
    table="users",
    where="age < ?",
    args=["30"]
)

Update

update_data = {"age": 31}
crud.update(
    table="users",
    data=update_data,
    where="name = ?",
    args=["Jane Smith"]
)

Delete

crud.delete(
    table="users",
    where="name = ?",
    args=["Jane Smith"]
)

Async Usage

import anyio
from turso_python import AsyncTursoConnection, AsyncTursoCRUD

async def main():
    async with AsyncTursoConnection() as conn:
        crud = AsyncTursoCRUD(conn)
        await crud.create("users", {"name": "Alice", "age": 30})
        res = await crud.read("users", "age > ?", [20])
        print(res)

anyio.run(main)

Batch Operations

For bulk operations, use the TursoBatch class:

from turso_python.batch import TursoBatch

batch = TursoBatch(connection)

users = [
    {"name": "User 1", "age": 25},
    {"name": "User 2", "age": 30},
    {"name": "User 3", "age": 35}
]

batch.batch_insert("users", users)

Advanced Queries

The TursoAdvancedQueries class handles complex operations:

from turso_python.advanced_queries import TursoAdvancedQueries

advanced = TursoAdvancedQueries(connection)

# Perform a JOIN operation
result = advanced.join_query(
    base_table="users",
    join_table="orders",
    join_condition="users.id = orders.user_id",
    select_columns="users.name, orders.order_date",
    where="orders.amount > 100"
)

Schema Management

The TursoSchemaManager helps with table operations:

from turso_python.crud import TursoSchemaManager

schema_manager = TursoSchemaManager(connection)

# Create a new table
schema = {
    "id": "INTEGER PRIMARY KEY",
    "name": "TEXT NOT NULL",
    "email": "TEXT UNIQUE",
    "created_at": "TIMESTAMP DEFAULT CURRENT_TIMESTAMP"
}
schema_manager.create_table("users", schema)

# Drop a table
schema_manager.drop_table("old_table")

Database Creation

from turso_python.crud import TursoClient

client = TursoClient()

# Create a new database
client.create_database(
    org_name="your_org",
    db_name="new_database",
    group_name="default",
    api_token="your_api_token"
)

Error Handling

TursoPy includes basic error handling for common scenarios:

try:
    result = crud.read("non_existent_table")
except Exception as e:
    print(f"An error occurred: {e}")

Best Practices

  1. Always use environment variables for sensitive credentials
  2. Use batch operations for bulk inserts/updates
  3. Close connections when done (handled automatically in most cases)
  4. Use proper type hints in query arguments
  5. Handle errors appropriately in production code

Contributing

Contributions are welcome! As a solo developer project, I appreciate any help in improving TursoPy. Please feel free to:

  • Report bugs
  • Suggest features
  • Submit pull requests
  • Improve documentation

License

Apache 2.0 License

Support

For issues, questions, or suggestions, please open an issue on GitHub. As a solo developer, I'll do my best to respond in a timely manner.


Remember: TursoPy is designed to be simple and straightforward. While it might not have all the bells and whistles of other clients, it focuses on reliability and ease of use. Sometimes, simpler is better!

Note for 2024-11-24, I literally built this yesterday so I'm still tweaking some stuff and fixing some stuff

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

turso_python-1.8.tar.gz (42.4 kB view details)

Uploaded Source

Built Distribution

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

turso_python-1.8-py3-none-any.whl (24.7 kB view details)

Uploaded Python 3

File details

Details for the file turso_python-1.8.tar.gz.

File metadata

  • Download URL: turso_python-1.8.tar.gz
  • Upload date:
  • Size: 42.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.3

File hashes

Hashes for turso_python-1.8.tar.gz
Algorithm Hash digest
SHA256 9008547e4e5dfc40d97101e94ff08d2bbb9dd5437c2877876b1dd7a75e6f75f4
MD5 0b23dbc0440131c0b4f487e5e3eadce3
BLAKE2b-256 9427efe3a4cdde73abe46559d53e771b7da2d8ea23b3701857c1dd92afda67fc

See more details on using hashes here.

File details

Details for the file turso_python-1.8-py3-none-any.whl.

File metadata

  • Download URL: turso_python-1.8-py3-none-any.whl
  • Upload date:
  • Size: 24.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.3

File hashes

Hashes for turso_python-1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 34c8bd402d1e9c5b30a27066686213c90b7ec65ef5a13c4e24d85abf9851762d
MD5 ea4031f50a0c6e54b4b70cd4f73e85d4
BLAKE2b-256 44880f2eedbeb6ed9697c295222179a8bb5738f7e73e5b5055783b8f07b1313b

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