From cc97280a9521f0d6763fbc11defb025d5b6025ba Mon Sep 17 00:00:00 2001 From: Goradi Date: Tue, 19 Nov 2024 17:18:33 +0500 Subject: [PATCH] fix: insert dataclass support --- sqladmin/_queries.py | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/sqladmin/_queries.py b/sqladmin/_queries.py index 44ae2b9e..fcd596cf 100644 --- a/sqladmin/_queries.py +++ b/sqladmin/_queries.py @@ -189,8 +189,20 @@ async def _delete_async(self, pk: str, request: Request) -> None: await session.commit() await self.model_view.after_model_delete(obj, request) + def _prepare_insert_dataclass(self, data: dict[str, Any]) -> dict[str, Any]: + try: + init = { + k: v + for k, v in data.items() + if self.model_view.model.__dataclass_fields__[k].init # type: ignore[attr-defined] # caught in except block + } + except AttributeError: + return {} + else: + return init + def _insert_sync(self, data: dict[str, Any], request: Request) -> Any: - obj = self.model_view.model() + obj = self.model_view.model(**self._prepare_insert_dataclass(data)) with self.model_view.session_maker(expire_on_commit=False) as session: anyio.from_thread.run( @@ -205,7 +217,7 @@ def _insert_sync(self, data: dict[str, Any], request: Request) -> Any: return obj async def _insert_async(self, data: dict[str, Any], request: Request) -> Any: - obj = self.model_view.model() + obj = self.model_view.model(**self._prepare_insert_dataclass(data)) async with self.model_view.session_maker(expire_on_commit=False) as session: await self.model_view.on_model_change(data, obj, True, request)