from __future__ import annotations
from sqlalchemy import desc
from onegov.core.collection import Pagination
from onegov.election_day.models import DataSource
from onegov.election_day.models import DataSourceItem
from typing import TYPE_CHECKING
if TYPE_CHECKING:
from sqlalchemy.orm import Query
from sqlalchemy.orm import Session
from typing import Self
from uuid import UUID
[docs]
class DataSourceCollection(Pagination[DataSource]):
def __init__(self, session: Session, page: int = 0):
super().__init__(page)
[docs]
def __eq__(self, other: object) -> bool:
return isinstance(other, self.__class__) and self.page == other.page
[docs]
def subset(self) -> Query[DataSource]:
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, index)
[docs]
def query(self) -> Query[DataSource]:
return self.session.query(DataSource).order_by(
desc(DataSource.created))
[docs]
def by_id(self, id: UUID) -> DataSource | None:
return self.query().filter(DataSource.id == id).first()
[docs]
def add(self, source: DataSource) -> None:
self.session.add(source)
self.session.flush()
[docs]
def delete(self, source: DataSource) -> None:
self.session.delete(source)
self.session.flush()
[docs]
class DataSourceItemCollection(Pagination[DataSourceItem]):
def __init__(
self,
session: Session,
id: UUID | None = None,
page: int = 0
):
super().__init__(page)
[docs]
def __eq__(self, other: object) -> bool:
return isinstance(other, self.__class__) and self.page == other.page
[docs]
def subset(self) -> Query[DataSourceItem]:
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, self.id, index)
[docs]
def query(self) -> Query[DataSourceItem]:
query = self.session.query(DataSourceItem)
query = query.filter(DataSourceItem.source_id == self.id)
query = query.order_by(DataSourceItem.district, DataSourceItem.number)
return query
[docs]
def by_id(self, id: UUID) -> DataSourceItem | None:
query = self.session.query(DataSourceItem)
query = query.filter(DataSourceItem.id == id)
return query.first()
@property
[docs]
def source(self) -> DataSource | None:
query = self.session.query(DataSource)
query = query.filter(DataSource.id == self.id)
return query.first()
[docs]
def add(self, item: DataSourceItem) -> None:
assert self.id is not None
item.source_id = self.id
self.session.add(item)
self.session.flush()
[docs]
def delete(self, item: DataSourceItem) -> None:
self.session.delete(item)
self.session.flush()