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.3.tar.gz (18.7 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.3-py2.py3-none-any.whl (9.4 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

File hashes

Hashes for FunctionStoredController-0.0.3.tar.gz
Algorithm Hash digest
SHA256 a078620e07b697c6352c637a3a94eeee18f184d1687e0dcd80caabf793e710b0
MD5 718a398e5e07f09fd6b2f8ee2fda7f75
BLAKE2b-256 48e09a6c70e2faabd1a8ac86b04b89ca5c90273d2d91cdc765251d6d5d852674

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for functionstoredcontroller-0.0.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 66d74abe851b3d75efbf7a2eb25896dbb9ed61bd6e173be64c6a10a5e4ded800
MD5 015b55ba735283ba55b06a1e545c7818
BLAKE2b-256 198de2f6584c67c2999d696215f2ccd34e8070fd8d98fe391a90672be585a787

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