80 lines
2.2 KiB
Python
80 lines
2.2 KiB
Python
import datetime
|
|
from datetime import date as Date
|
|
|
|
from folkugat_web.config import date as config
|
|
from folkugat_web.dal.sql.sessions import query, write
|
|
from folkugat_web.model import sessions as model
|
|
from folkugat_web.model.sql import Order, OrderCol, Range
|
|
|
|
|
|
def get_date_names(date: Date) -> model.DateNames:
|
|
return model.DateNames(
|
|
day_name=config.DAY_NAMES_CAT[date.weekday()],
|
|
day=str(date.day),
|
|
month_name=config.MONTH_NAMES_CAT[date.month],
|
|
year=str(date.year),
|
|
)
|
|
|
|
|
|
def new_session() -> model.Session:
|
|
sessions = get_sessions()
|
|
if not sessions:
|
|
venue = model.SessionVenue()
|
|
else:
|
|
venue = sessions[-1].venue
|
|
return model.Session(venue=venue)
|
|
|
|
|
|
def get_sessions() -> list[model.Session]:
|
|
return query.get_sessions(order_by=OrderCol(model.SessionCols.DATE, Order.ASCENDING))
|
|
|
|
|
|
def get_next_sessions(limit: int | None = None, offset: int | None = None) -> list[model.Session]:
|
|
return query.get_sessions(
|
|
date_range=Range(gte=datetime.date.today()),
|
|
order_by=OrderCol(model.SessionCols.DATE, Order.ASCENDING),
|
|
limit=limit,
|
|
offset=offset,
|
|
)
|
|
|
|
|
|
def get_sessions_history(limit: int | None = None, offset: int | None = None) -> list[model.Session]:
|
|
return query.get_sessions(
|
|
date_range=Range(lt=datetime.date.today()),
|
|
order_by=OrderCol(model.SessionCols.DATE, Order.DESCENDING),
|
|
limit=limit,
|
|
offset=offset,
|
|
)
|
|
|
|
|
|
def get_next_session() -> model.Session | None:
|
|
return next(iter(get_next_sessions(limit=1,)), None)
|
|
|
|
|
|
def get_live_session() -> model.Session | None:
|
|
return next(iter(query.get_sessions(is_live=True)), None)
|
|
|
|
|
|
def get_session(session_id: int) -> model.Session | None:
|
|
return next(iter(query.get_sessions(session_id=session_id)), None)
|
|
|
|
|
|
def insert_session(session: model.Session):
|
|
return write.insert_session(session)
|
|
|
|
|
|
def set_session(session: model.Session):
|
|
write.update_session(session)
|
|
|
|
|
|
def delete_session(session_id: int):
|
|
write.delete_session_by_id(session_id)
|
|
|
|
|
|
def stop_live_sessions():
|
|
write.stop_live_sessions()
|
|
|
|
|
|
def set_live_session(session_id: int):
|
|
write.set_live_session(session_id=session_id)
|