fix: preserve stored recipe slugs during hydration (#7294)

Co-authored-by: Michael Genson <71845777+michael-genson@users.noreply.github.com>
Co-authored-by: Michael Genson <genson.michael@gmail.com>
This commit is contained in:
harshitlarl
2026-03-27 20:38:48 +05:30
committed by GitHub
parent 63c549ae5c
commit c029a639fb
5 changed files with 77 additions and 4 deletions

View File

@@ -203,13 +203,19 @@ class RepositoryRecipes(HouseholdRepositoryGeneric[Recipe, RecipeModel]):
def update(self, match_value: str | int | UUID4, new_data: dict | Recipe) -> Recipe:
new_data = new_data if isinstance(new_data, dict) else new_data.model_dump()
entry = self._query_one(match_value=match_value)
if new_name := new_data.get("name"):
new_data["slug"] = entry.slug if new_name == entry.name else create_recipe_slug(new_name)
# Handle explicit group_id injection for related items that require it
for organizer_field in ["tags", "recipe_category", "tools"]:
for organizer in new_data.get(organizer_field, []):
organizer["group_id"] = self.group_id
return super().update(match_value, new_data)
entry.update(session=self.session, **new_data)
self.session.commit()
return self.schema.model_validate(entry)
def page_all( # type: ignore
self,

View File

@@ -240,7 +240,7 @@ class Recipe(RecipeSummary):
@field_validator("slug", mode="before")
def validate_slug(slug: str, info: ValidationInfo):
if not info.data.get("name"):
if slug or not info.data.get("name"):
return slug
return create_recipe_slug(info.data["name"])