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.
- 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.
To add and install this package as a dependency of your project, run poetry add querytyper
.
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",
],
}
Prerequisites
1. Set up Git to use SSH
- Generate an SSH key and add the SSH key to your GitHub account.
- Configure SSH to automatically load your SSH keys:
cat << EOF >> ~/.ssh/config Host * AddKeysToAgent yes IgnoreUnknown UseKeychain UseKeychain yes EOF
2. Install Docker
- Install Docker Desktop.
- Enable Use Docker Compose V2 in Docker Desktop's preferences window.
- Linux only:
- Export your user's user id and group id so that files created in the Dev Container are owned by your user:
cat << EOF >> ~/.bashrc export UID=$(id --user) export GID=$(id --group) EOF
- Export your user's user id and group id so that files created in the Dev Container are owned by your user:
3. Install VS Code or PyCharm
- Install VS Code and VS Code's Dev Containers extension. Alternatively, install PyCharm.
- 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:
- ⭐️ GitHub Codespaces: click on Code and select Create codespace to start a Dev Container with GitHub Codespaces.
- ⭐️ 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.
- Dev Container: clone this repository, open it with VS Code, and run Ctrl/⌘ + ⇧ + P → Dev Containers: Reopen in Container.
- PyCharm: clone this repository, open it with PyCharm, and configure Docker Compose as a remote interpreter with the
dev
service. - 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 rundocker 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 topyproject.toml
andpoetry.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 bypyproject.toml
. - Run
cz bump
to bump the package's version, update theCHANGELOG.md
, and create a git tag.