Source code for agency.collections.memberships

from __future__ import annotations

from onegov.agency.models import ExtendedAgency
from onegov.agency.models import ExtendedAgencyMembership
from onegov.agency.models import ExtendedPerson
from onegov.agency.utils import filter_modified_or_created
from onegov.core.collection import GenericCollection
from onegov.core.collection import Pagination
from sqlalchemy import or_
from sqlalchemy.orm import joinedload


from typing import Self
from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from sqlalchemy.orm import Query
    from sqlalchemy.orm import Session
    from typing import TypedDict
    from typing_extensions import Unpack

[docs] class FilterParams(TypedDict, total=False):
[docs] updated_gt: str | None
[docs] updated_ge: str | None
[docs] updated_eq: str | None
[docs] updated_le: str | None
[docs] updated_lt: str | None
[docs] class PaginatedMembershipCollection( GenericCollection[ExtendedAgencyMembership], Pagination[ExtendedAgencyMembership] ): def __init__( self, session: Session, page: int = 0, agency: str | None = None, person: str | None = None, updated_gt: str | None = None, updated_ge: str | None = None, updated_eq: str | None = None, updated_le: str | None = None, updated_lt: str | None = None, exclude_hidden: bool = True ) -> None: super().__init__(session)
[docs] self.page = page
[docs] self.agency = agency
[docs] self.person = person
# filter keywords
[docs] self.updated_gt = updated_gt
[docs] self.updated_ge = updated_ge
[docs] self.updated_eq = updated_eq
[docs] self.updated_le = updated_le
[docs] self.updated_lt = updated_lt
# end filter keywords
[docs] self.exclude_hidden = exclude_hidden
@property
[docs] def model_class(self) -> type[ExtendedAgencyMembership]: return ExtendedAgencyMembership
[docs] def __eq__(self, other: object) -> bool: return ( isinstance(other, self.__class__) and other.page == self.page and other.agency == self.agency and other.person == self.person )
[docs] def subset(self) -> Query[ExtendedAgencyMembership]: return self.query()
@property
[docs] def page_index(self) -> int: return self.page
[docs] def page_by_index(self, index: int) -> Self: return self.__class__( self.session, page=index, updated_gt=self.updated_gt, updated_ge=self.updated_ge, updated_eq=self.updated_eq, updated_le=self.updated_le, updated_lt=self.updated_lt, )
[docs] def for_filter(self, **kwargs: Unpack[FilterParams]) -> Self: return self.__class__( session=self.session, updated_gt=kwargs.get('updated_gt', self.updated_gt), updated_ge=kwargs.get('updated_ge', self.updated_ge), updated_eq=kwargs.get('updated_eq', self.updated_eq), updated_le=kwargs.get('updated_le', self.updated_le), updated_lt=kwargs.get('updated_lt', self.updated_lt), )
[docs] def query(self) -> Query[ExtendedAgencyMembership]: query = super().query() if self.exclude_hidden: query = query.options(joinedload(ExtendedAgencyMembership.agency)) query = query.options(joinedload(ExtendedAgencyMembership.person)) query = query.filter( or_( ExtendedAgencyMembership.meta['access'] == 'public', ExtendedAgencyMembership.meta['access'] == None, ), ExtendedAgencyMembership.published.is_(True) ) query = query.filter( ExtendedAgencyMembership.agency_id.isnot(None) ) query = query.filter( ExtendedAgency.id == ExtendedAgencyMembership.agency_id, or_( ExtendedAgency.meta['access'] == 'public', ExtendedAgency.meta['access'] == None, ), ExtendedAgency.published.is_(True) ) query = query.filter( ExtendedAgencyMembership.person_id.isnot(None) ) query = query.filter( ExtendedPerson.id == ExtendedAgencyMembership.person_id, or_( ExtendedPerson.meta['access'] == 'public', ExtendedPerson.meta['access'] == None, ), ExtendedPerson.published.is_(True) ) if self.agency: query = query.filter( ExtendedAgencyMembership.agency_id == self.agency ) if self.person: query = query.filter( ExtendedAgencyMembership.person_id == self.person ) if self.updated_gt: query = filter_modified_or_created(query, '>', self.updated_gt, ExtendedAgencyMembership) if self.updated_ge: query = filter_modified_or_created(query, '>=', self.updated_ge, ExtendedAgencyMembership) if self.updated_eq: query = filter_modified_or_created(query, '==', self.updated_eq, ExtendedAgencyMembership) if self.updated_le: query = filter_modified_or_created(query, '<=', self.updated_le, ExtendedAgencyMembership) if self.updated_lt: query = filter_modified_or_created(query, '<', self.updated_lt, ExtendedAgencyMembership) if self.updated_lt: query = filter_modified_or_created(query, '<', self.updated_lt, ExtendedAgencyMembership) return query