ohmyapi 0.1.11__tar.gz → 0.1.12__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.
Files changed (24) hide show
  1. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/PKG-INFO +22 -5
  2. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/README.md +21 -4
  3. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/pyproject.toml +1 -1
  4. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/cli.py +13 -4
  5. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/__init__.py +0 -0
  6. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/__main__.py +0 -0
  7. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/builtin/auth/__init__.py +0 -0
  8. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/builtin/auth/models.py +0 -0
  9. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/builtin/auth/permissions.py +0 -0
  10. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/builtin/auth/routes.py +0 -0
  11. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/__init__.py +0 -0
  12. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/runtime.py +0 -0
  13. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/scaffolding.py +0 -0
  14. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/templates/app/__init__.py.j2 +0 -0
  15. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/templates/app/models.py.j2 +0 -0
  16. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/templates/app/routes.py.j2 +0 -0
  17. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/templates/project/README.md.j2 +0 -0
  18. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/templates/project/pyproject.toml.j2 +0 -0
  19. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/core/templates/project/settings.py.j2 +0 -0
  20. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/db/__init__.py +0 -0
  21. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/db/exceptions.py +0 -0
  22. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/db/model/__init__.py +0 -0
  23. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/db/model/model.py +0 -0
  24. {ohmyapi-0.1.11 → ohmyapi-0.1.12}/src/ohmyapi/router.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: ohmyapi
3
- Version: 0.1.11
3
+ Version: 0.1.12
4
4
  Summary: A Django-like but async web-framework based on FastAPI and TortoiseORM.
5
5
  License-Expression: MIT
6
6
  Keywords: fastapi,tortoise,orm,async,web-framework
@@ -267,8 +267,6 @@ In your `routes.py`:
267
267
 
268
268
  ```python
269
269
  from ohmyapi.router import APIRouter, Depends
270
-
271
- from ohmyapi_auth.models import User
272
270
  from ohmyapi_auth import (
273
271
  models as auth,
274
272
  permissions,
@@ -276,7 +274,7 @@ from ohmyapi_auth import (
276
274
 
277
275
  from .models import Tournament
278
276
 
279
- router = APIRouter(prefix="/tournament")
277
+ router = APIRouter(prefix="/tournament", tags=["Tournament"])
280
278
 
281
279
 
282
280
  @router.get("/")
@@ -294,10 +292,11 @@ Use Tortoise's `Manager` to implement model-level permissions.
294
292
 
295
293
  ```python
296
294
  from ohmyapi.db import Manager
295
+ from ohmyapi_auth.models import User
297
296
 
298
297
 
299
298
  class TeamManager(Manager):
300
- async def for_user(self, user: ohmyapi_auth.models.User):
299
+ async def for_user(self, user: User):
301
300
  return await self.filter(members=user).all()
302
301
 
303
302
 
@@ -308,6 +307,24 @@ class Team(Model):
308
307
  manager = TeamManager()
309
308
  ```
310
309
 
310
+ Use the custom manager in your FastAPI route handler:
311
+
312
+ ```python
313
+ from ohmyapi.router import APIRouter
314
+ from ohmyapi_auth import (
315
+ models as auth,
316
+ permissions,
317
+ )
318
+
319
+ router = APIRouter(prefix="/tournament", tags=["Tournament"])
320
+
321
+
322
+ @router.get("/teams")
323
+ async def teams(user: auth.User = Depends(permissions.require_authenticated)):
324
+ queryset = Team.for_user(user)
325
+ return await Tournament.Schema.many.from_queryset(queryset)
326
+ ```
327
+
311
328
  ## Shell
312
329
 
313
330
  Similar to Django, you can attach to an interactive shell with your project already loaded inside.
@@ -235,8 +235,6 @@ In your `routes.py`:
235
235
 
236
236
  ```python
237
237
  from ohmyapi.router import APIRouter, Depends
238
-
239
- from ohmyapi_auth.models import User
240
238
  from ohmyapi_auth import (
241
239
  models as auth,
242
240
  permissions,
@@ -244,7 +242,7 @@ from ohmyapi_auth import (
244
242
 
245
243
  from .models import Tournament
246
244
 
247
- router = APIRouter(prefix="/tournament")
245
+ router = APIRouter(prefix="/tournament", tags=["Tournament"])
248
246
 
249
247
 
250
248
  @router.get("/")
@@ -262,10 +260,11 @@ Use Tortoise's `Manager` to implement model-level permissions.
262
260
 
263
261
  ```python
264
262
  from ohmyapi.db import Manager
263
+ from ohmyapi_auth.models import User
265
264
 
266
265
 
267
266
  class TeamManager(Manager):
268
- async def for_user(self, user: ohmyapi_auth.models.User):
267
+ async def for_user(self, user: User):
269
268
  return await self.filter(members=user).all()
270
269
 
271
270
 
@@ -276,6 +275,24 @@ class Team(Model):
276
275
  manager = TeamManager()
277
276
  ```
278
277
 
278
+ Use the custom manager in your FastAPI route handler:
279
+
280
+ ```python
281
+ from ohmyapi.router import APIRouter
282
+ from ohmyapi_auth import (
283
+ models as auth,
284
+ permissions,
285
+ )
286
+
287
+ router = APIRouter(prefix="/tournament", tags=["Tournament"])
288
+
289
+
290
+ @router.get("/teams")
291
+ async def teams(user: auth.User = Depends(permissions.require_authenticated)):
292
+ queryset = Team.for_user(user)
293
+ return await Tournament.Schema.many.from_queryset(queryset)
294
+ ```
295
+
279
296
  ## Shell
280
297
 
281
298
  Similar to Django, you can attach to an interactive shell with your project already loaded inside.
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "ohmyapi"
3
- version = "0.1.11"
3
+ version = "0.1.12"
4
4
  description = "A Django-like but async web-framework based on FastAPI and TortoiseORM."
5
5
  license = "MIT"
6
6
  keywords = ["fastapi", "tortoise", "orm", "async", "web-framework"]
@@ -16,13 +16,13 @@ Find your loaded project singleton via identifier: `p`
16
16
 
17
17
  @app.command()
18
18
  def startproject(name: str):
19
- """Create a new OhMyAPI project in the given directory"""
19
+ """Create a new OhMyAPI project in the given directory."""
20
20
  scaffolding.startproject(name)
21
21
 
22
22
 
23
23
  @app.command()
24
24
  def startapp(app_name: str, root: str = "."):
25
- """Create a new app with the given name in your OhMyAPI project"""
25
+ """Create a new app with the given name in your OhMyAPI project."""
26
26
  scaffolding.startapp(app_name, root)
27
27
 
28
28
 
@@ -93,6 +93,10 @@ def migrate(app: str = "*", root: str = "."):
93
93
 
94
94
  @app.command()
95
95
  def createsuperuser(root: str = "."):
96
+ """Create a superuser in the DB.
97
+
98
+ This requires the presence of `ohmyapi_auth` in your INSTALLED_APPS to work.
99
+ """
96
100
  project_path = Path(root).resolve()
97
101
  project = runtime.Project(project_path)
98
102
  if not project.is_app_installed("ohmyapi_auth"):
@@ -103,9 +107,14 @@ def createsuperuser(root: str = "."):
103
107
  import ohmyapi_auth
104
108
  email = input("E-Mail: ")
105
109
  username = input("Username: ")
106
- password = getpass("Password: ")
110
+ password1, password2 = "foo", "bar"
111
+ while password1 != password2:
112
+ password1 = getpass("Password: ")
113
+ password2 = getpass("Repeat Password: ")
114
+ if password1 != password2:
115
+ print("Passwords didn't match!")
107
116
  user = ohmyapi_auth.models.User(email=email, username=username, is_staff=True, is_admin=True)
108
- user.set_password(password)
117
+ user.set_password(password1)
109
118
  asyncio.run(project.init_orm())
110
119
  asyncio.run(user.save())
111
120
  asyncio.run(project.close_orm())
File without changes