-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #21 from guivaloz:guivaloz/snippets
Nuevos modulos.
- Loading branch information
Showing
16 changed files
with
325 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
""" | ||
Domicilios, modelos | ||
""" | ||
|
||
from typing import List | ||
|
||
from sqlalchemy import ForeignKey, String | ||
from sqlalchemy.orm import Mapped, mapped_column, relationship | ||
|
||
from lib.database import Base | ||
from lib.universal_mixin import UniversalMixin | ||
|
||
|
||
class Domicilio(Base, UniversalMixin): | ||
"""Domicilio""" | ||
|
||
# Nombre de la tabla | ||
__tablename__ = "domicilios" | ||
|
||
# Clave primaria | ||
id: Mapped[int] = mapped_column(primary_key=True) | ||
|
||
# Clave foránea | ||
distrito_id: Mapped[int] = mapped_column(ForeignKey("distritos.id")) | ||
distrito: Mapped["Distrito"] = relationship(back_populates="domicilios") | ||
|
||
# Columnas | ||
edificio: Mapped[str] = mapped_column(String(64), unique=True) | ||
estado: Mapped[str] = mapped_column(String(64)) | ||
municipio: Mapped[str] = mapped_column(String(64)) | ||
calle: Mapped[str] = mapped_column(String(256)) | ||
num_ext: Mapped[str] = mapped_column(String(24)) | ||
num_int: Mapped[str] = mapped_column(String(24)) | ||
colonia: Mapped[str] = mapped_column(String(256)) | ||
cp: Mapped[int] | ||
completo: Mapped[str] = mapped_column(String(1024)) | ||
|
||
# Hijos | ||
oficinas: Mapped[List["Oficina"]] = relationship("Oficina", back_populates="domicilio") | ||
|
||
def __repr__(self): | ||
"""Representación""" | ||
return f"<Domicilio {self.edificio}>" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
""" | ||
Oficinas, modelos | ||
""" | ||
|
||
from datetime import time | ||
from typing import List | ||
|
||
from sqlalchemy import ForeignKey, String | ||
from sqlalchemy.orm import Mapped, mapped_column, relationship | ||
|
||
from lib.database import Base | ||
from lib.universal_mixin import UniversalMixin | ||
|
||
|
||
class Oficina(Base, UniversalMixin): | ||
"""Oficina""" | ||
|
||
TIPOS = { | ||
"NO DEFINIDO": "NO DEFINIDO", | ||
"O.J. DE 1RA. INSTANCIA": "O.J. DE 1RA. INSTANCIA", | ||
"O.J. DE 2DA. INSTANCIA": "O.J. DE 2DA. INSTANCIA", | ||
"ADMINISTRATICO Y/O U. ADMIN.": "ADMINISTRATICO Y/O U. ADMIN.", | ||
} | ||
|
||
# Nombre de la tabla | ||
__tablename__ = "oficinas" | ||
|
||
# Clave primaria | ||
id: Mapped[int] = mapped_column(primary_key=True) | ||
|
||
# Claves foráneas | ||
distrito_id: Mapped[int] = mapped_column(ForeignKey("distritos.id")) | ||
distrito: Mapped["Distrito"] = relationship(back_populates="oficinas") | ||
domicilio_id: Mapped[int] = mapped_column(ForeignKey("domicilios.id")) | ||
domicilio: Mapped["Domicilio"] = relationship(back_populates="oficinas") | ||
|
||
# Columnas | ||
clave: Mapped[str] = mapped_column(String(32), unique=True) | ||
descripcion: Mapped[str] = mapped_column(String(512)) | ||
descripcion_corta: Mapped[str] = mapped_column(String(64)) | ||
es_jurisdiccional: Mapped[bool] = mapped_column(default=False) | ||
apertura: Mapped[time] | ||
cierre: Mapped[time] | ||
limite_personas: Mapped[int] | ||
telefono: Mapped[str] = mapped_column(String(48)) | ||
extension: Mapped[str] = mapped_column(String(24)) | ||
|
||
# Hijos | ||
usuarios: Mapped[List["Usuario"]] = relationship("Usuario", back_populates="oficina") | ||
|
||
def __repr__(self): | ||
"""Representación""" | ||
return f"<Oficina {self.id}>" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
""" | ||
Domicilios v4, CRUD (create, read, update, and delete) | ||
""" | ||
|
||
from typing import Any | ||
|
||
from sqlalchemy.orm import Session | ||
|
||
from lib.exceptions import MyIsDeletedError, MyNotExistsError | ||
|
||
from ...core.domicilios.models import Domicilio | ||
|
||
|
||
def get_domicilios(database: Session) -> Any: | ||
"""Consultar los domicilio activos""" | ||
consulta = database.query(Domicilio) | ||
return consulta.filter_by(estatus="A").order_by(Domicilio.id) | ||
|
||
|
||
def get_domicilio(database: Session, domicilio_id: int) -> Domicilio: | ||
"""Consultar un domicilio por su id""" | ||
domicilio = database.query(Domicilio).get(domicilio_id) | ||
if domicilio is None: | ||
raise MyNotExistsError("No existe ese domicilio") | ||
if domicilio.estatus != "A": | ||
raise MyIsDeletedError("No es activo ese domicilio, está eliminado") | ||
return domicilio |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
""" | ||
Domicilios v4, rutas (paths) | ||
""" | ||
|
||
from typing import Annotated | ||
|
||
from fastapi import APIRouter, Depends, HTTPException, status | ||
from fastapi_pagination.ext.sqlalchemy import paginate | ||
|
||
from lib.database import Session, get_db | ||
from lib.exceptions import MyAnyError | ||
from lib.fastapi_pagination_custom_page import CustomPage | ||
|
||
from ...core.permisos.models import Permiso | ||
from ..usuarios.authentications import UsuarioInDB, get_current_active_user | ||
from .crud import get_domicilio, get_domicilios | ||
from .schemas import DomicilioOut, OneDomicilioOut | ||
|
||
domicilios = APIRouter(prefix="/v4/domicilios", tags=["categoria"]) | ||
|
||
|
||
@domicilios.get("", response_model=CustomPage[DomicilioOut]) | ||
async def paginado_domicilios( | ||
current_user: Annotated[UsuarioInDB, Depends(get_current_active_user)], | ||
database: Annotated[Session, Depends(get_db)], | ||
): | ||
"""Paginado de domicilios""" | ||
if current_user.permissions.get("DOMICILIOS", 0) < Permiso.VER: | ||
raise HTTPException(status_code=status.HTTP_403_FORBIDDEN, detail="Forbidden") | ||
try: | ||
resultados = get_domicilios(database) | ||
except MyAnyError as error: | ||
return CustomPage(success=False, errors=[str(error)]) | ||
return paginate(resultados) | ||
|
||
|
||
@domicilios.get("/{domicilio_id}", response_model=OneDomicilioOut) | ||
async def detalle_domicilio( | ||
current_user: Annotated[UsuarioInDB, Depends(get_current_active_user)], | ||
database: Annotated[Session, Depends(get_db)], | ||
domicilio_id: int, | ||
): | ||
"""Detalle de una domicilio a partir de su id""" | ||
if current_user.permissions.get("DOMICILIOS", 0) < Permiso.VER: | ||
raise HTTPException(status_code=status.HTTP_403_FORBIDDEN, detail="Forbidden") | ||
try: | ||
domicilio = get_domicilio(database, domicilio_id) | ||
except MyAnyError as error: | ||
return OneDomicilioOut(success=False, errors=[str(error)]) | ||
return OneDomicilioOut.model_validate(domicilio) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
""" | ||
Domicilios v4, esquemas de pydantic | ||
""" | ||
|
||
from pydantic import BaseModel, ConfigDict | ||
|
||
from lib.schemas_base import OneBaseOut | ||
|
||
|
||
class DomicilioOut(BaseModel): | ||
"""Esquema para entregar domicilios""" | ||
|
||
id: int | None = None | ||
edificio: str | None = None | ||
model_config = ConfigDict(from_attributes=True) | ||
|
||
|
||
class OneDomicilioOut(OneBaseOut): | ||
"""Esquema para entregar un domicilio""" | ||
|
||
data: DomicilioOut | None = None |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
""" | ||
Oficinas v4, CRUD (create, read, update, and delete) | ||
""" | ||
|
||
from typing import Any | ||
|
||
from sqlalchemy.orm import Session | ||
|
||
from lib.exceptions import MyIsDeletedError, MyNotExistsError | ||
|
||
from ...core.oficinas.models import Oficina | ||
|
||
|
||
def get_oficinas(database: Session) -> Any: | ||
"""Consultar los oficinas activos""" | ||
consulta = database.query(Oficina) | ||
return consulta.filter_by(estatus="A").order_by(Oficina.id) | ||
|
||
|
||
def get_oficina(database: Session, oficina_id: int) -> Oficina: | ||
"""Consultar un oficina por su id""" | ||
oficina = database.query(Oficina).get(oficina_id) | ||
if oficina is None: | ||
raise MyNotExistsError("No existe ese oficina") | ||
if oficina.estatus != "A": | ||
raise MyIsDeletedError("No es activo ese oficina, está eliminado") | ||
return oficina |
Oops, something went wrong.