Source code for landsgemeinde.collections.votum

from __future__ import annotations

from functools import cached_property
from onegov.core.collection import GenericCollection
from onegov.landsgemeinde.models import AgendaItem
from onegov.landsgemeinde.models import Assembly
from onegov.landsgemeinde.models import Votum
from sqlalchemy.orm import undefer


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from datetime import date
    from sqlalchemy.orm import Query
    from sqlalchemy.orm import Session
    from uuid import UUID


[docs] class VotumCollection(GenericCollection[Votum]): def __init__( self, session: Session, date: date | None = None, agenda_item_number: int | None = None ) -> None:
[docs] self.session = session
[docs] self.date = date
[docs] self.agenda_item_number = agenda_item_number
@property
[docs] def model_class(self) -> type[Votum]: return Votum
[docs] def query(self) -> Query[Votum]: query = super().query() if self.date or self.agenda_item_number: query = query.join(Votum.agenda_item) if self.date: query = query.join(AgendaItem.assembly) query = query.filter(Assembly.date == self.date) if self.agenda_item_number: query = query.filter(AgendaItem.number == self.agenda_item_number) query = query.order_by(Votum.number) return query
[docs] def by_id( self, id: UUID # type:ignore[override] ) -> Votum | None: return super().query().filter(Votum.id == id).first()
[docs] def by_number(self, number: int) -> Votum | None: if not self.date or not self.agenda_item_number: return None query = self.query().filter(Votum.number == number) query = query.options(undefer(Votum.content)) return query.first()
@cached_property
[docs] def assembly(self) -> Assembly | None: if self.date is not None: query = self.session.query(Assembly) query = query.filter(Assembly.date == self.date) return query.first() return None
@cached_property
[docs] def agenda_item(self) -> AgendaItem | None: if self.assembly is not None and self.agenda_item_number is not None: query = self.session.query(AgendaItem) query = query.filter(AgendaItem.assembly_id == self.assembly.id) query = query.filter(AgendaItem.number == self.agenda_item_number) return query.first() return None