ohmyapi 0.1.11__py3-none-any.whl → 0.1.13__py3-none-any.whl

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.
ohmyapi/cli.py CHANGED
@@ -1,4 +1,5 @@
1
1
  import asyncio
2
+ import atexit
2
3
  import importlib
3
4
  import sys
4
5
  import typer
@@ -16,13 +17,13 @@ Find your loaded project singleton via identifier: `p`
16
17
 
17
18
  @app.command()
18
19
  def startproject(name: str):
19
- """Create a new OhMyAPI project in the given directory"""
20
+ """Create a new OhMyAPI project in the given directory."""
20
21
  scaffolding.startproject(name)
21
22
 
22
23
 
23
24
  @app.command()
24
25
  def startapp(app_name: str, root: str = "."):
25
- """Create a new app with the given name in your OhMyAPI project"""
26
+ """Create a new app with the given name in your OhMyAPI project."""
26
27
  scaffolding.startapp(app_name, root)
27
28
 
28
29
 
@@ -45,6 +46,28 @@ def shell(root: str = "."):
45
46
  project_path = Path(root).resolve()
46
47
  project = runtime.Project(project_path)
47
48
 
49
+ # Ensure the ORM is shutdown
50
+ async def close_project():
51
+ try:
52
+ await project.close_orm()
53
+ print("Tortoise ORM closed successfully.")
54
+ except Exception as e:
55
+ print(f"Error closing ORM: {e}")
56
+
57
+ def cleanup():
58
+ loop = None
59
+ try:
60
+ loop = asyncio.get_running_loop()
61
+ except RuntimeError:
62
+ pass
63
+ if loop and loop.is_running():
64
+ asyncio.create_task(close_project())
65
+ else:
66
+ asyncio.run(close_project())
67
+
68
+ # Ensure the ORM is initialized
69
+ asyncio.run(project.init_orm())
70
+
48
71
  try:
49
72
  from IPython import start_ipython
50
73
  shell_vars = {
@@ -56,11 +79,13 @@ def shell(root: str = "."):
56
79
  c.TerminalInteractiveShell.banner2 = banner.format(**{
57
80
  "project_name": f"{f'{project.settings.PROJECT_NAME} ' if getattr(project.settings, 'PROJECT_NAME', '') else ''}[{Path(project_path).resolve()}]",
58
81
  })
82
+ atexit.register(cleanup)
59
83
  start_ipython(argv=[], user_ns=shell_vars, config=c)
60
84
  except ImportError:
61
85
  typer.echo("IPython is not installed. Falling back to built-in Python shell.")
62
86
  import code
63
- code.interact(local={"settings": project.settings})
87
+ atexit.register(cleanup)
88
+ code.interact(local={"p": project})
64
89
 
65
90
 
66
91
  @app.command()
@@ -93,6 +118,10 @@ def migrate(app: str = "*", root: str = "."):
93
118
 
94
119
  @app.command()
95
120
  def createsuperuser(root: str = "."):
121
+ """Create a superuser in the DB.
122
+
123
+ This requires the presence of `ohmyapi_auth` in your INSTALLED_APPS to work.
124
+ """
96
125
  project_path = Path(root).resolve()
97
126
  project = runtime.Project(project_path)
98
127
  if not project.is_app_installed("ohmyapi_auth"):
@@ -103,9 +132,14 @@ def createsuperuser(root: str = "."):
103
132
  import ohmyapi_auth
104
133
  email = input("E-Mail: ")
105
134
  username = input("Username: ")
106
- password = getpass("Password: ")
135
+ password1, password2 = "foo", "bar"
136
+ while password1 != password2:
137
+ password1 = getpass("Password: ")
138
+ password2 = getpass("Repeat Password: ")
139
+ if password1 != password2:
140
+ print("Passwords didn't match!")
107
141
  user = ohmyapi_auth.models.User(email=email, username=username, is_staff=True, is_admin=True)
108
- user.set_password(password)
142
+ user.set_password(password1)
109
143
  asyncio.run(project.init_orm())
110
144
  asyncio.run(user.save())
111
145
  asyncio.run(project.close_orm())
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: ohmyapi
3
- Version: 0.1.11
3
+ Version: 0.1.13
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.
@@ -336,12 +353,17 @@ Out[2]:
336
353
  Routes:
337
354
  - APIRoute(path='/auth/login', name='login', methods=['POST'])
338
355
  - APIRoute(path='/auth/refresh', name='refresh_token', methods=['POST'])
339
- - APIRoute(path='/auth/me', name='me', methods=['GET'])
340
- - APIRoute(path='/auth/introspect', name='introspect', methods=['GET'])}
356
+ - APIRoute(path='/auth/introspect', name='introspect', methods=['GET'])
357
+ - APIRoute(path='/auth/me', name='me', methods=['GET']),
358
+ 'tournament': App: tournament
359
+ Models:
360
+ - Tournament
361
+ - Event
362
+ - Team
363
+ Routes:
364
+ - APIRoute(path='/tournament/', name='list', methods=['GET'])}
341
365
 
342
366
  In [3]: from tournament.models import Tournament
343
- Out[3]:
344
-
345
367
  ```
346
368
 
347
369
 
@@ -4,7 +4,7 @@ ohmyapi/builtin/auth/__init__.py,sha256=TY1RKgwWmJ6FKz_v4J3m0Ang69qSmtVDLe4rqjLk
4
4
  ohmyapi/builtin/auth/models.py,sha256=Xsxn9m5RTgY2a0PPfW3wTj77ocuuISytdl4ec_TR_kw,1524
5
5
  ohmyapi/builtin/auth/permissions.py,sha256=jf-I2b9rIOw2EF4Kga-_Bz1ZPPHU0vHNaXGrDQSwhSI,145
6
6
  ohmyapi/builtin/auth/routes.py,sha256=iMxmgP6TSpMrtSKf-g7mc60NcOiw8FRkngUroalGCyk,5519
7
- ohmyapi/cli.py,sha256=ZJVBRpSS297y00H4zffYQzkeIIVmVpGS4BYGpxT1FPo,3430
7
+ ohmyapi/cli.py,sha256=Mip1eBKYyu1hmUHbNW-1kSMc05EJOTVXqdI0c0r_B4g,4440
8
8
  ohmyapi/core/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
9
9
  ohmyapi/core/runtime.py,sha256=l5zffc4VTwQOo7G9mfiYHsPGapMONRX_jtO_z9QaKHU,8577
10
10
  ohmyapi/core/scaffolding.py,sha256=iMymscokJ-YqzB0ZTC-gcc2T71o73577j9tnb2x8lH8,2572
@@ -19,7 +19,7 @@ ohmyapi/db/exceptions.py,sha256=I7AubrdqQF_UvAvzKqz2ve08-BkXHzEWXnwG300StHE,35
19
19
  ohmyapi/db/model/__init__.py,sha256=k3StTNuKatpwZo_Z5JBFa-927eJrzibFE8U4SA82asc,32
20
20
  ohmyapi/db/model/model.py,sha256=BajFtLlQ1s0mZ2hj-_JNQhLQmxuVe-Lw2LuW5t2C7Rw,1579
21
21
  ohmyapi/router.py,sha256=hutccsrP9RT8W5O6uBDhOJehwqrkRoPzaUI5zoHPh9A,55
22
- ohmyapi-0.1.11.dist-info/METADATA,sha256=GrlZqJvBkvNdRy-8KvRptZfoxF-gAChKDqvsZqUsBC0,8235
23
- ohmyapi-0.1.11.dist-info/WHEEL,sha256=M5asmiAlL6HEcOq52Yi5mmk9KmTVjY2RDPtO4p9DMrc,88
24
- ohmyapi-0.1.11.dist-info/entry_points.txt,sha256=wb3lw8-meAlpiv1mqcQ3m25ukL7djagU_w89GkrC37k,43
25
- ohmyapi-0.1.11.dist-info/RECORD,,
22
+ ohmyapi-0.1.13.dist-info/METADATA,sha256=UcPMZIqwNTN5LrJ29RYgyLbhMUmCHsVMGm5UFCOHdU0,8812
23
+ ohmyapi-0.1.13.dist-info/WHEEL,sha256=M5asmiAlL6HEcOq52Yi5mmk9KmTVjY2RDPtO4p9DMrc,88
24
+ ohmyapi-0.1.13.dist-info/entry_points.txt,sha256=wb3lw8-meAlpiv1mqcQ3m25ukL7djagU_w89GkrC37k,43
25
+ ohmyapi-0.1.13.dist-info/RECORD,,