mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-07-22 22:59:41 +02:00
* refactor(backend): ♻️ cleanup duplicate code in http services * refactor(backend): ♻️ refactor database away from singleton design removed the database single and instead injected the session into a new Database class that is created during each request life-cycle. Now sessions no longer need to be passed into each method on the database All tests pass, but there are likely some hidden breaking changes that were not discovered. * fix venv * disable venv cache * fix install script * bump poetry version * postgres fixes * revert install * fix db initialization for postgres * add postgres to docker * refactor(backend): ♻️ cleanup unused and duplicate code in http services * refactor(backend): remove sessions from arguments * refactor(backend): ♻️ convert units and ingredients to use http service class * test(backend): ✅ add unit and food tests * lint * update tags * re-enable cache * fix missing fraction in db * fix lint Co-authored-by: hay-kot <hay-kot@pm.me>
24 lines
917 B
Python
24 lines
917 B
Python
from datetime import date
|
|
|
|
from mealie.db.models.group import GroupMealPlan
|
|
from mealie.schema.meal_plan.new_meal import ReadPlanEntry
|
|
|
|
from ._access_model import AccessModel
|
|
|
|
|
|
class MealDataAccessModel(AccessModel[ReadPlanEntry, GroupMealPlan]):
|
|
def get_slice(self, start: date, end: date, group_id: int) -> list[ReadPlanEntry]:
|
|
start = start.strftime("%Y-%m-%d")
|
|
end = end.strftime("%Y-%m-%d")
|
|
qry = self.session.query(GroupMealPlan).filter(
|
|
GroupMealPlan.date.between(start, end),
|
|
GroupMealPlan.group_id == group_id,
|
|
)
|
|
|
|
return [self.schema.from_orm(x) for x in qry.all()]
|
|
|
|
def get_today(self, group_id: int) -> list[ReadPlanEntry]:
|
|
today = date.today()
|
|
qry = self.session.query(GroupMealPlan).filter(GroupMealPlan.date == today, GroupMealPlan.group_id == group_id)
|
|
|
|
return [self.schema.from_orm(x) for x in qry.all()]
|