Metadata-Version: 2.4
Name: scruby-return-json
Version: 0.2.7
Summary: Plugin for Scruby - In search methods, returns results in the form of dictionaries.
Keywords: plugin,scruby,json,database
Author: kebasyaty
Author-email: kebasyaty <kebasyaty@gmail.com>
License-Expression: MIT
License-File: LICENSE
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: POSIX
Classifier: Operating System :: POSIX :: Linux
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3.14
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Topic :: Software Development :: Libraries
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Database
Classifier: Typing :: Typed
Requires-Dist: anyio>=4.12.1
Requires-Dist: scruby-plugin>=0.3.6
Requires-Python: >=3.12, <4.0
Project-URL: Homepage, https://kebasyaty.github.io/scruby-return-json/
Project-URL: Repository, https://github.com/kebasyaty/scruby-return-json
Project-URL: Source, https://github.com/kebasyaty/scruby-return-json
Project-URL: Bug Tracker, https://github.com/kebasyaty/scruby-return-json/issues
Project-URL: Changelog, https://github.com/kebasyaty/scruby-return-json/blob/v0/CHANGELOG.md
Description-Content-Type: text/markdown

<div align="center">
  <p align="center">
    <a href="https://github.com/kebasyaty/scruby-return-json">
      <img
        height="80"
        alt="Logo"
        src="https://raw.githubusercontent.com/kebasyaty/scruby-return-json/main/assets/logo.svg">
    </a>
  </p>
  <p>
    <h1>scruby-return-json</h1>
    <h3>Plugin for Scruby - In search methods, returns result as json strings.</h3>
    <p align="center">
      <a href="https://github.com/kebasyaty/scruby-return-json/actions/workflows/test.yml" alt="Build Status"><img src="https://github.com/kebasyaty/scruby-return-json/actions/workflows/test.yml/badge.svg" alt="Build Status"></a>
      <a href="https://kebasyaty.github.io/scruby-return-json/" alt="Docs"><img src="https://img.shields.io/badge/docs-available-brightgreen.svg" alt="Docs"></a>
      <a href="https://pypi.python.org/pypi/scruby-return-json/" alt="PyPI pyversions"><img src="https://img.shields.io/pypi/pyversions/scruby-return-json.svg" alt="PyPI pyversions"></a>
      <a href="https://pypi.python.org/pypi/scruby-return-json/" alt="PyPI status"><img src="https://img.shields.io/pypi/status/scruby-return-json.svg" alt="PyPI status"></a>
      <a href="https://pypi.python.org/pypi/scruby-return-json/" alt="PyPI version fury.io"><img src="https://badge.fury.io/py/scruby-return-json.svg" alt="PyPI version fury.io"></a>
      <br>
      <a href="https://pyrefly.org/" alt="Types: Pyrefly"><img src="https://img.shields.io/badge/types-Pyrefly-FFB74D.svg" alt="Types: Pyrefly"></a>
      <a href="https://docs.astral.sh/ruff/" alt="Code style: Ruff"><img src="https://img.shields.io/badge/code%20style-Ruff-FDD835.svg" alt="Code style: Ruff"></a>
      <a href="https://pypi.org/project/scruby-return-json"><img src="https://img.shields.io/pypi/format/scruby-return-json" alt="Format"></a>
      <a href="https://pepy.tech/projects/scruby-return-json"><img src="https://static.pepy.tech/badge/scruby-return-json" alt="PyPI Downloads"></a>
      <a href="https://github.com/kebasyaty/scruby-return-json/blob/main/LICENSE" alt="GitHub license"><img src="https://img.shields.io/github/license/kebasyaty/scruby-return-json" alt="GitHub license"></a>
    </p>
    <p align="center">
      scruby-return-json is a plugin for the <a href="https://pypi.org/project/scruby/" alt="Scruby">Scruby</a> project.
    </p>
  </p>
</div>

##

<br>

[![Documentation](https://raw.githubusercontent.com/kebasyaty/scruby-return-json/v0/assets/links/documentation.svg "Documentation")](https://kebasyaty.github.io/scruby-return-json/ "Documentation")

[![Requirements](https://raw.githubusercontent.com/kebasyaty/scruby-return-json/v0/assets/links/requirements.svg "Requirements")](https://github.com/kebasyaty/scruby-return-json/blob/v0/REQUIREMENTS.md "Requirements")

## Installation

```shell
uv add scruby-return-json
```

## Usage

[![Examples](https://raw.githubusercontent.com/kebasyaty/scruby-return-json/v0/assets/links/examples.svg "Examples")](https://kebasyaty.github.io/scruby-return-json/latest/pages/usage/ "Examples")

```python
import anyio
from typing import Any
from pydantic import Field
from scruby import Scruby, ScrubyModel, ScrubySettings
from scruby_return_json import ReturnJson

# Plugins connection.
ScrubySettings.plugins = [
    ReturnJson,
]


class Car(ScrubyModel):
    """Car model."""

    brand: str = Field(strict=True, frozen=True)
    model: str = Field(strict=True, frozen=True)
    year: int = Field(strict=True, frozen=True)
    power_reserve: int = Field(strict=True, frozen=True)
    description: str = Field(strict=True)
    # key is always at bottom
    key: str = Field(
        strict=True,
        frozen=True,
        default_factory=lambda data: f"{data['brand']}:{data['model']}",
    )


async def main() -> None:
    """Example."""
    # Get collection `Car`
    car_coll = await Scruby.collection(Car)
    # Create cars.
    for num in range(1, 10):
        car = Car(
            brand="Mazda",
            model=f"EZ-6 {num}",
            year=2025,
            power_reserve=600,
            description="Electric cars are the future of the global automotive industry.",
        )
        await car_coll.add_doc(car)

    # Find one car
    car_json: str | None = await car_coll.plugins.returnJson.find_one(c
        filter_fn=lambda doc: doc.brand == "Mazda" and doc.model == "EZ-6 9",
    )
    if car_json is not None:
      print(car_json)
    else:
      print("Not Found")

    # Fand many cars
    car_json_list: list[str] | None = await car_coll.plugins.returnJson.find_many(
        filter_fn=lambda doc: doc.brand == "Mazda",
    )
    if car_json_list is not None:
      print(car_json_list)
    else:
      print("Not Found")

    # Full database deletion.
    # Hint: The main purpose is tests.
    Scruby.napalm()


if __name__ == "__main__":
    anyio.run(main)
```

<br>

[![Changelog](https://raw.githubusercontent.com/kebasyaty/scruby-return-json/v0/assets/links/changelog.svg "Changelog")](https://github.com/kebasyaty/scruby-return-json/blob/v0/CHANGELOG.md "Changelog")

[![GPL-3.0](https://raw.githubusercontent.com/kebasyaty/scruby-return-json/v0/assets/links/mit.svg "MIT")](https://github.com/kebasyaty/scruby-return-json/blob/main/LICENSE "MIT")
