Skip to main content

Контроллер для работы с хранимыми процедурами

Project description

Контроллер для работы с хранимыми процедурами

Пример использования с функциями

from controller.core.models import FunctionModel
from typing import Optional


class GetOrder(FunctionModel):
    """Хранимка для получения списка заказов"""
    _func_name = 'data.get_order'
    id: Optional[int]
    status_id: Optional[int]
    cemetery_id: Optional[int]
    customer_id: Optional[int]
    search: str = ''
    rows: Optional[int] = None
    page: int = 1
    user_id: Optional[int]


order = GetOrder(id=1984).get()  # Вернет 1 объект {}
all_orders = GetOrder(id=1984).all()  # Вернет все товары [{}]
top_5_orders = GetOrder(status_id=2).get(5)  # Вернет 5 заказов
all_orders_count = GetOrder().length()  # Вернет кол-во заказов 1923

Пример использования с процедурами

from controller.core.models import ProcedureModel
from typing import Optional


class RemoveOrder(ProcedureModel):
    """Хранимка для удаления заказа"""
    _func_name = 'data.remove_order'
    id: Optional[int]
    status_id: Optional[int]
    cemetery_id: Optional[int]
    customer_id: Optional[int]
    user_id: Optional[int]


response = RemoveOrder(id=1984).execute()  # Удалит заказ

Поддержка Django

Основная часть расширения включает в себя особенность в качестве параметра в хранимку передавать request, а также специальное поле для получения user_id (AuthUser)

from controller.core.models import FunctionModel
from controller.django.models import DjangoModelMixin
from controller.django.fields import AuthUser
from django.http.response import JsonResponse
from typing import Optional
from controller.core.fields import Const


class GetOrder(FunctionModel, DjangoModelMixin):
    """Комментарий"""
    _func_name = 'data.get_order'
    id: Optional[int]
    status_id: Optional[int]
    cemetery_id: Optional[int]
    customer_id: Optional[int]
    search: str = ''
    rows: Optional[int] = None
    page: int = 1
    user_id: AuthUser


class GetOrderCompleted(GetOrder):
    status_id: Const = 2


def home(request):
    return JsonResponse({'item': GetOrderCompleted(request).get()})
# Хранимка get_order заберет в себя все необходимые параметры,
# и провалидирует их и перезапишет status_id на 2. То есть с фронта можно не отправлять пустые значения или значения,
# которые не требуют переопределения

Валидация ошибок и создание своих полей

Есть возможность прописать свое поле для каких-то данных, например, для телефона у нас должны быть числа и длинной равной 10

from controller.core.models import FunctionModel
from controller.core.fields import CustomField
from pydantic import ValidationError


class Phone(CustomField):
    __root__ = str

    @classmethod
    def validate(cls, value, values, config, field) -> str:
        value = str(value)
        if value and (not value.isdigit() or len(value) != 10):
            raise ValueError("Это не номер телефона")
        return value


class GetOrder(FunctionModel):
    """Комментарий"""
    _func_name = 'data.get_order'
    phone: Phone = ''


try:
    GetOrder(phone=12)
except ValidationError as e:
    print(e.json())
"""
[
  {
    "loc": [
      "phone"
    ],
    "msg": "Это не номер телефона",
    "type": "value_error"
  }
]
"""

Если данное поле валидацию не пройдет, то мы получим ошибку, которую можно вернуть в формате json

FastAPI

from controller.core.models import FunctionModel
from controller.core.db import DataBase
from typing import Optional
from fastapi import FastAPI, Depends

app = FastAPI()
db = DataBase()


class GetOrder(FunctionModel):
    """Хранимка для получения заказов"""
    _func_name = 'data.get_order'
    _db = db
    id: Optional[int]
    status_id: Optional[int]


@app.get('/')
def home(data: GetOrder = Depends()):
    return data

Результат:

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

FunctionStoredController-0.0.11.tar.gz (19.6 kB view details)

Uploaded Source

Built Distribution

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

functionstoredcontroller-0.0.11-py2.py3-none-any.whl (10.2 kB view details)

Uploaded Python 2Python 3

File details

Details for the file FunctionStoredController-0.0.11.tar.gz.

File metadata

File hashes

Hashes for FunctionStoredController-0.0.11.tar.gz
Algorithm Hash digest
SHA256 ecb1806db763489485074cfb446819711d155cfe8f903f695cb535b78921e35e
MD5 4019edb600e590c9bbbe60bd132a96b3
BLAKE2b-256 5e1371149955cafab2b0f221cfa551a773248efafeae3092fb6332dfb62405cf

See more details on using hashes here.

File details

Details for the file functionstoredcontroller-0.0.11-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for functionstoredcontroller-0.0.11-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 2d9231b59652308ced1c7d66aac42376ebcb6c00f16039047fa1cf401cce9e56
MD5 fd4175094e6070223975e2719185b995
BLAKE2b-256 612e31205ff26ea5bc7a18c6fb107748ab0800126dc11db28e5a1453e2530d6a

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