Skip to main content

Fast, batteries-included, business-oriented, opinionated REST APIs framework

Project description

Kwik

Kwik Logo

⚠️ Pre-Release Software Warning

Kwik v1.0 has been released and is ready for production use. The internal APIs, data structures, and framework interfaces are now stable. While not guaranteed, we strive to maintain backward compatibility following semantic versioning principles.


Documentation: https://davide.mezzogori.com/kwik/

codecov

Fast, batteries-included, business-oriented, opinionated REST APIs framework

Acknowledgments

Python 3.12+

Kwik stands on the shoulder of a couple of giants:

  • FastAPI: for the underlying REST API server.
  • Pydantic: for the data validation and serialization.
  • SQLAlchemy: for the ORM part.

Installation

$ pip install kwik

or

$ uv add kwik

It will install Kwik and all its dependencies.

Development

Setup

# Clone the repository
git clone https://github.com/dmezzogori/kwik.git
cd kwik

# Install dependencies using uv
uv sync

# Start development server with hot reload
kwik

Testing

# Run all tests with coverage (testcontainers automatically manages PostgreSQL)
pytest --cov=src/kwik --cov-report=term-missing

# Run tests in parallel (faster)
pytest -n auto

# Run specific test file
pytest tests/crud/test_crud_users.py

# Run only unit tests (skip integration tests)
pytest -m "not integration"

Note: Tests use testcontainers to automatically manage the PostgreSQL database. No manual database setup required (just docker).

Code Quality

# Run linter and formatter
ruff check
ruff format

Documentation

# Start documentation website locally
cd docs
docker compose up

# Access at http://localhost:8000

Listing queries (DX)

  • Unified dependency kwik.dependencies.ListQuery combines pagination, sorting, and filtering for list endpoints.
  • Query params supported:
    • skip and limit for pagination (stable default ordering by primary key when no sort is provided)
    • sorting as comma-separated fields with optional direction, e.g. ?sorting=name:asc,id:desc
    • filter_key and value for simple equality filters, e.g. ?filter_key=is_active&value=true
  • Example endpoint:
    • def list_users(q: ListQuery, context: UserContext) -> Paginated[UserProfile]: total, data = crud_users.get_multi(context=context, **q) return {"total": total, "data": data}
  • Invalid filter/sort fields return HTTP 400 with a clear message.

Contributing

  1. Create a feature branch (git checkout -b feature/your-feature-name)
  2. Make your changes following the existing code style
  3. Add tests for new functionality
  4. Run tests and ensure they pass
  5. Run linting and fix any issues
  6. Commit your changes (git commit -am '<Your commit message>')
  7. Push to the branch (git push origin feature/your-feature-name)
  8. Create a Pull Request

License

This project is licensed under the terms of the MIT license.

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

kwik-1.5.0.tar.gz (1.0 MB view details)

Uploaded Source

Built Distribution

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

kwik-1.5.0-py3-none-any.whl (58.4 kB view details)

Uploaded Python 3

File details

Details for the file kwik-1.5.0.tar.gz.

File metadata

  • Download URL: kwik-1.5.0.tar.gz
  • Upload date:
  • Size: 1.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for kwik-1.5.0.tar.gz
Algorithm Hash digest
SHA256 a8b54499ed4a10a8cb51372c51443eb2a6538937585c5f65e76bb0d8a1dad249
MD5 c77d4768b5f91ca8e6fe30a8b3f2e4ea
BLAKE2b-256 e176012f02541a9497b9eee9d5617dc366a7bffbf665ac5f96210a78cf6e0bbd

See more details on using hashes here.

File details

Details for the file kwik-1.5.0-py3-none-any.whl.

File metadata

  • Download URL: kwik-1.5.0-py3-none-any.whl
  • Upload date:
  • Size: 58.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.8 {"installer":{"name":"uv","version":"0.10.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for kwik-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d4206fe223b7865ac733d4ce0365dafa10d352f8098f0204cefc67344350a6d9
MD5 2df46954d69459ddde5091745e646f3b
BLAKE2b-256 d203611489b87f03e1be49dc2e1562b5b592cd2b505ac26ae19c974a2b9a9fc5

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