Skip to main content

Add your description here

Project description

PocketBase ORM

A Python ORM (Object-Relational Mapper) for PocketBase that provides Pydantic model integration and automatic schema synchronization.

Features

  • 🚀 Pydantic model integration for data validation and serialization
  • 🔄 Automatic schema synchronization with PocketBase collections
  • 📦 Support for most PocketBase field types including relations and file uploads
  • 🛠️ Simple and intuitive API for CRUD operations

Installation

uv install pocketbase-orm

Quick Start

from pocketbase_orm import PBModel
from pydantic import EmailStr, AnyUrl, Field
from datetime import datetime, timezone
from pocketbase.client import FileUpload

# Define your models
class RelatedModel(PBModel, collection="related_models"):  # Optionally specify collection name
    name: str

class Example(PBModel):  # Collection name will be "examples" by default
    text_field: str
    number_field: int
    is_active: bool
    url_field: AnyUrl
    created_at: datetime
    options: list[str]
    email_field: EmailStr | None = None
    related_model: RelatedModel | str = Field(..., description="Related model reference")
    image: FileUpload | str = Field(..., description="Image file upload")

# Initialize PocketBase client and bind it to the ORM
client = PBModel.init_client(
    "YOUR_POCKETBASE_URL",
    "admin@example.com",
    "password"
)

# Sync collection schemas
RelatedModel.sync_collection()
Example.sync_collection()

# Create and save records
related_model = RelatedModel(name="Related Model")
related_model.save()

# Create a new record with file upload
with open("image.png", "rb") as f:
    example = Example(
        text_field="Test with image",
        number_field=123,
        is_active=True,
        email_field="test@example.com",
        url_field="http://example.com",
        created_at=datetime.now(timezone.utc),
        options=["option1", "option2"],
        related_model=related_model.id,
        image=FileUpload(("image.png", f))
    )
    example.save()

# Query records
full_list = Example.get_full_list()
one = Example.get_one("RECORD_ID")
first = Example.get_first_list_item(filter='email_field = "test@example.com"')
filtered_list = Example.get_list(filter='email_field = "test@example.com"')

# Get file contents
image_bytes = example.get_file_contents("image")

Model Definition

Models inherit from PBModel and use Pydantic field types:

from enum import Enum

class UserType(str, Enum):
    ADMIN = "admin"
    REGULAR = "regular"
    GUEST = "guest"

class MyModel(PBModel, collection="my_models"):  # Specify custom collection name
    name: str
    age: int
    email: EmailStr | None = None
    user_type: UserType  # Will be created as a select field in PocketBase

The collection name will be automatically derived from the class name (pluralized) if not specified using the collection parameter when subclassing PBModel.

Supported Field Types

  • Text: str
  • Number: int, float
  • Boolean: bool
  • Email: EmailStr
  • URL: AnyUrl
  • DateTime: datetime
  • JSON: List, Dict
  • File: FileUpload | str
  • Relation: Union[RelatedModel, str]
  • Select: Enum

API Reference

Class Methods

  • bind_client(client: PocketBase): Bind PocketBase client to the model class
  • sync_collection(): Create or update the collection schema in PocketBase
  • delete_collection(): Delete the entire collection from PocketBase
  • get_one(id: str, **kwargs) -> T: Get a single record by ID
  • get_list(*args, **kwargs) -> List[T]: Get a paginated list of records
  • get_full_list(*args, **kwargs) -> List[T]: Get all records
  • get_first_list_item(*args, **kwargs) -> T: Get the first matching record
  • delete_by_id(id: str, **kwargs): Delete a record by ID

Instance Methods

  • save() -> T: Create or update the record
  • delete(): Delete the current record
  • get_file_contents(field: str) -> bytes: Get the contents of a file field

Limitations

  • The ORM currently supports basic CRUD operations and schema synchronization
  • Complex queries should use the PocketBase client directly
  • Relationship handling is limited to single relations
  • Indexes must be created manually
  • Schema syncing currently relies on a fork until https://github.com/vaphes/pocketbase/pull/120 is merged

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

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

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

pocketbase_orm-0.16.0.tar.gz (8.0 kB view details)

Uploaded Source

Built Distribution

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

pocketbase_orm-0.16.0-py3-none-any.whl (8.8 kB view details)

Uploaded Python 3

File details

Details for the file pocketbase_orm-0.16.0.tar.gz.

File metadata

  • Download URL: pocketbase_orm-0.16.0.tar.gz
  • Upload date:
  • Size: 8.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.6

File hashes

Hashes for pocketbase_orm-0.16.0.tar.gz
Algorithm Hash digest
SHA256 1c5c00aafbdaf120a18d0c471a267d6249081636faa27d74b63c1bf37ec5cd86
MD5 68304dafb8e0ae5c55fe89eb82a29f7b
BLAKE2b-256 c3fa3ab362704e00aa25ec6471dc5422225a733a788dc56f8bb9de687d68a0af

See more details on using hashes here.

File details

Details for the file pocketbase_orm-0.16.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pocketbase_orm-0.16.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9a581afa64b3934936bd78d0fdc9eaa226e2b0264f1a9c1fd72f29f232d5095f
MD5 aae93b7c3118a2121cf698f8f0fbef6b
BLAKE2b-256 aa326f0bb129dc200a923787fb3ca9d0dee759a7941191880e56c853aad43897

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