django-ninja-aio-crud 0.8.2__tar.gz → 0.8.4__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/PKG-INFO +1 -1
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/__init__.py +1 -1
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/views.py +16 -10
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/LICENSE +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/README.md +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/api.py +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/auth.py +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/exceptions.py +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/models.py +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/parsers.py +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/renders.py +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/schemas.py +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/ninja_aio/types.py +0 -0
- {django_ninja_aio_crud-0.8.2 → django_ninja_aio_crud-0.8.4}/pyproject.toml +0 -0
|
@@ -87,7 +87,9 @@ class APIViewSet:
|
|
|
87
87
|
self.schema_out, self.schema_in, self.schema_update = self.get_schemas()
|
|
88
88
|
self.path_schema = self._generate_path_schema()
|
|
89
89
|
self.filters_schema = self._generate_filters_schema()
|
|
90
|
-
self.router_tag =
|
|
90
|
+
self.router_tag = " ".join(
|
|
91
|
+
self.model._meta.verbose_name.capitalize().split(" ")
|
|
92
|
+
)
|
|
91
93
|
self.router = Router(tags=[self.router_tag])
|
|
92
94
|
self.path = "/"
|
|
93
95
|
self.path_retrieve = f"{{{self.model_util.model_pk_name}}}/"
|
|
@@ -110,17 +112,18 @@ class APIViewSet:
|
|
|
110
112
|
}
|
|
111
113
|
|
|
112
114
|
def _auth_view(self, view_type: str):
|
|
113
|
-
|
|
115
|
+
auth = getattr(self, f"{view_type}_auth", None)
|
|
116
|
+
return auth if auth is not NOT_SET else self.auth
|
|
114
117
|
|
|
115
118
|
def get_view_auth(self):
|
|
116
119
|
return self._auth_view("get")
|
|
117
|
-
|
|
120
|
+
|
|
118
121
|
def post_view_auth(self):
|
|
119
122
|
return self._auth_view("post")
|
|
120
|
-
|
|
123
|
+
|
|
121
124
|
def patch_view_auth(self):
|
|
122
125
|
return self._auth_view("patch")
|
|
123
|
-
|
|
126
|
+
|
|
124
127
|
def delete_view_auth(self):
|
|
125
128
|
return self._auth_view("delete")
|
|
126
129
|
|
|
@@ -163,7 +166,7 @@ class APIViewSet:
|
|
|
163
166
|
auth=self.post_view_auth(),
|
|
164
167
|
response={201: self.schema_out, self.error_codes: GenericMessageSchema},
|
|
165
168
|
)
|
|
166
|
-
async def create(request: HttpRequest, data: self.schema_in):
|
|
169
|
+
async def create(request: HttpRequest, data: self.schema_in): # type: ignore
|
|
167
170
|
return 201, await self.model_util.create_s(request, data, self.schema_out)
|
|
168
171
|
|
|
169
172
|
create.__name__ = f"create_{self.model_util.model_name}"
|
|
@@ -180,7 +183,8 @@ class APIViewSet:
|
|
|
180
183
|
)
|
|
181
184
|
@paginate(self.pagination_class)
|
|
182
185
|
async def list(
|
|
183
|
-
request: HttpRequest,
|
|
186
|
+
request: HttpRequest,
|
|
187
|
+
filters: Query[self.filters_schema] = None, # type: ignore
|
|
184
188
|
):
|
|
185
189
|
qs = self.model.objects.select_related()
|
|
186
190
|
if isinstance(self.model, ModelSerializerMeta):
|
|
@@ -205,7 +209,7 @@ class APIViewSet:
|
|
|
205
209
|
auth=self.get_view_auth(),
|
|
206
210
|
response={200: self.schema_out, self.error_codes: GenericMessageSchema},
|
|
207
211
|
)
|
|
208
|
-
async def retrieve(request: HttpRequest, pk: Path[self.path_schema]):
|
|
212
|
+
async def retrieve(request: HttpRequest, pk: Path[self.path_schema]): # type: ignore
|
|
209
213
|
obj = await self.model_util.get_object(request, self._get_pk(pk))
|
|
210
214
|
return await self.model_util.read_s(request, obj, self.schema_out)
|
|
211
215
|
|
|
@@ -219,7 +223,9 @@ class APIViewSet:
|
|
|
219
223
|
response={200: self.schema_out, self.error_codes: GenericMessageSchema},
|
|
220
224
|
)
|
|
221
225
|
async def update(
|
|
222
|
-
request: HttpRequest,
|
|
226
|
+
request: HttpRequest,
|
|
227
|
+
data: self.schema_update, # type: ignore
|
|
228
|
+
pk: Path[self.path_schema], # type: ignore
|
|
223
229
|
):
|
|
224
230
|
return await self.model_util.update_s(
|
|
225
231
|
request, data, self._get_pk(pk), self.schema_out
|
|
@@ -234,7 +240,7 @@ class APIViewSet:
|
|
|
234
240
|
auth=self.delete_view_auth(),
|
|
235
241
|
response={204: None, self.error_codes: GenericMessageSchema},
|
|
236
242
|
)
|
|
237
|
-
async def delete(request: HttpRequest, pk: Path[self.path_schema]):
|
|
243
|
+
async def delete(request: HttpRequest, pk: Path[self.path_schema]): # type: ignore
|
|
238
244
|
return 204, await self.model_util.delete_s(request, self._get_pk(pk))
|
|
239
245
|
|
|
240
246
|
delete.__name__ = f"delete_{self.model_util.model_name}"
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|