Skip to main content

A Python package to queryy databases using a fully typed syntax.

Project description

Open in Dev Containers

Querytyper

Querytyper is a Python package to query MongoDB using a fully typed syntax. It leverages the Pydantic library for defining and validating data models, providing a seamless and type-safe experience.

Features

  • Construct MongoDB queries using Python's native syntax with type hints.
  • Leverage Pydantic models to define your MongoDB document structure and query filters efficiently.
  • Build complex queries using logical operators and comparisons in a natural and expressive way.

Using

To add and install this package as a dependency of your project, run poetry add querytyper.

A simple example:

from pydantic import BaseModel, EmailStr
from querytyper import MongoFilterMeta, MongoQuery

class User(BaseModel):
    """User database model."""
    id: int
    name: str
    age: int
    email: EmailStr

class UserFilter(User, metaclass=MongoFilterMeta):
    """User query filter."""

query = MongoQuery(
        (UserFilter.name == "John")
        & (UserFilter.age >= 10)
        & (
            UserFilter.email
            in [
                "john@example.com",
                "john@gmail.com",
            ]
        )
    )
print(query)
{
    "name": "John",
    "age": {"$gte": 10},
    "email": [
        "john@example.com",
        "john@gmail.com",
    ],
}

Contributing

Prerequisites
1. Set up Git to use SSH
  1. Generate an SSH key and add the SSH key to your GitHub account.
  2. Configure SSH to automatically load your SSH keys:
    cat << EOF >> ~/.ssh/config
    Host *
      AddKeysToAgent yes
      IgnoreUnknown UseKeychain
      UseKeychain yes
    EOF
    
2. Install Docker
  1. Install Docker Desktop.
3. Install VS Code or PyCharm
  1. Install VS Code and VS Code's Dev Containers extension. Alternatively, install PyCharm.
  2. Optional: install a Nerd Font such as FiraCode Nerd Font and configure VS Code or configure PyCharm to use it.
Development environments

The following development environments are supported:

  1. ⭐️ GitHub Codespaces: click on Code and select Create codespace to start a Dev Container with GitHub Codespaces.
  2. ⭐️ Dev Container (with container volume): click on Open in Dev Containers to clone this repository in a container volume and create a Dev Container with VS Code.
  3. Dev Container: clone this repository, open it with VS Code, and run Ctrl/⌘ + + PDev Containers: Reopen in Container.
  4. PyCharm: clone this repository, open it with PyCharm, and configure Docker Compose as a remote interpreter with the dev service.
  5. Terminal: clone this repository, open it with your terminal, and run docker compose up --detach dev to start a Dev Container in the background, and then run docker compose exec dev zsh to open a shell prompt in the Dev Container.
Developing
  • This project follows the Conventional Commits standard to automate Semantic Versioning and Keep A Changelog with Commitizen.
  • Run poe from within the development environment to print a list of Poe the Poet tasks available to run on this project.
  • Run poetry add {package} from within the development environment to install a run time dependency and add it to pyproject.toml and poetry.lock. Add --group test or --group dev to install a CI or development dependency, respectively.
  • Run poetry update from within the development environment to upgrade all dependencies to the latest versions allowed by pyproject.toml.
  • Run cz bump to bump the package's version, update the CHANGELOG.md, and create a git tag.

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

querytyper-0.1.0.tar.gz (7.1 kB view details)

Uploaded Source

Built Distribution

querytyper-0.1.0-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file querytyper-0.1.0.tar.gz.

File metadata

  • Download URL: querytyper-0.1.0.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.8.18 Linux/6.2.0-1019-azure

File hashes

Hashes for querytyper-0.1.0.tar.gz
Algorithm Hash digest
SHA256 42ac91e27cf69be712e62a066b3ba69e97ce1c3cfa741a0f36298ca5cb613c4c
MD5 47e84aea186d0fa31c20b59b3e6f4d30
BLAKE2b-256 ae49b217a108a6e7d2d36804c655b81a6156bcbf2308cc0a59c2cacc4aff5d15

See more details on using hashes here.

File details

Details for the file querytyper-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: querytyper-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.8.18 Linux/6.2.0-1019-azure

File hashes

Hashes for querytyper-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a255af13e15e8437d33bd0f91aaa523f62434bd9cc60f0c53df50453c6b7353e
MD5 73e38a7f8c58a38b4c039caf3001f50a
BLAKE2b-256 ed13f862d1a9edde45b22fe274d8af1db7db6697b3b22a4fce2b293a56aea7fe

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page