wiederverwendbar 0.8.5__py3-none-any.whl → 0.9.0__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.
Files changed (67) hide show
  1. wiederverwendbar/__init__.py +8 -6
  2. wiederverwendbar/branding/__init__.py +1 -0
  3. wiederverwendbar/branding/settings.py +85 -0
  4. wiederverwendbar/console/__init__.py +3 -0
  5. wiederverwendbar/console/console.py +199 -0
  6. wiederverwendbar/console/out_files.py +19 -0
  7. wiederverwendbar/console/settings.py +9 -0
  8. wiederverwendbar/default.py +4 -1
  9. wiederverwendbar/fastapi/__init__.py +3 -0
  10. wiederverwendbar/fastapi/app.py +385 -0
  11. wiederverwendbar/fastapi/dependencies.py +11 -0
  12. wiederverwendbar/fastapi/settings.py +39 -0
  13. wiederverwendbar/functions/is_coroutine_function.py +19 -0
  14. wiederverwendbar/inspect.py +26 -0
  15. wiederverwendbar/logger/__init__.py +0 -1
  16. wiederverwendbar/logger/handlers/rich_console_handler.py +15 -6
  17. wiederverwendbar/logger/handlers/stream_console_handler.py +3 -16
  18. wiederverwendbar/logger/log_levels.py +4 -0
  19. wiederverwendbar/logger/settings.py +15 -20
  20. wiederverwendbar/pydantic/file_config.py +20 -4
  21. wiederverwendbar/rich/__init__.py +2 -0
  22. wiederverwendbar/rich/console.py +215 -0
  23. wiederverwendbar/rich/settings.py +26 -0
  24. wiederverwendbar/sqlalchemy/base.py +4 -4
  25. wiederverwendbar/task_manger/task.py +1 -4
  26. wiederverwendbar/task_manger/task_manager.py +14 -19
  27. wiederverwendbar/typer/__init__.py +3 -1
  28. wiederverwendbar/typer/app.py +172 -0
  29. wiederverwendbar/typer/settings.py +14 -0
  30. wiederverwendbar/warnings.py +6 -0
  31. {wiederverwendbar-0.8.5.dist-info → wiederverwendbar-0.9.0.dist-info}/METADATA +9 -6
  32. {wiederverwendbar-0.8.5.dist-info → wiederverwendbar-0.9.0.dist-info}/RECORD +34 -49
  33. wiederverwendbar/examples/__init__.py +0 -0
  34. wiederverwendbar/examples/before_after_wrap.py +0 -74
  35. wiederverwendbar/examples/colors.py +0 -16
  36. wiederverwendbar/examples/extended_thread.py +0 -28
  37. wiederverwendbar/examples/file_config.py +0 -11
  38. wiederverwendbar/examples/indexable_model.py +0 -19
  39. wiederverwendbar/examples/logger.py +0 -31
  40. wiederverwendbar/examples/logger_context/__init__.py +0 -0
  41. wiederverwendbar/examples/logger_context/example.py +0 -58
  42. wiederverwendbar/examples/logger_context/example_module.py +0 -13
  43. wiederverwendbar/examples/mongoengine/__init__.py +0 -0
  44. wiederverwendbar/examples/mongoengine/automatic_reference.py +0 -25
  45. wiederverwendbar/examples/mongoengine/db.py +0 -7
  46. wiederverwendbar/examples/mongoengine/log_streamer.py +0 -9
  47. wiederverwendbar/examples/mongoengine/logger.py +0 -25
  48. wiederverwendbar/examples/post_init.py +0 -29
  49. wiederverwendbar/examples/route.py +0 -12
  50. wiederverwendbar/examples/singletons.py +0 -59
  51. wiederverwendbar/examples/sqlalchemy/__init__.py +0 -0
  52. wiederverwendbar/examples/sqlalchemy/db.py +0 -89
  53. wiederverwendbar/examples/starlette_admin/__init__.py +0 -0
  54. wiederverwendbar/examples/starlette_admin/action_log.py +0 -126
  55. wiederverwendbar/examples/starlette_admin/action_log_file_download.py +0 -99
  56. wiederverwendbar/examples/starlette_admin/action_log_form.py +0 -149
  57. wiederverwendbar/examples/starlette_admin/action_log_thread.py +0 -192
  58. wiederverwendbar/examples/starlette_admin/automatic_reference_admin.py +0 -47
  59. wiederverwendbar/examples/starlette_admin/generic_embedded_document_field.py +0 -74
  60. wiederverwendbar/examples/starlette_admin/multi_path_admin.py +0 -18
  61. wiederverwendbar/examples/task_manager.py +0 -55
  62. wiederverwendbar/examples/test_file.py +0 -14
  63. wiederverwendbar/examples/typer_resolve_defaults.py +0 -15
  64. wiederverwendbar/examples/uvicorn_server.py +0 -32
  65. wiederverwendbar/logger/terminal_out_files.py +0 -10
  66. {wiederverwendbar-0.8.5.dist-info → wiederverwendbar-0.9.0.dist-info}/WHEEL +0 -0
  67. {wiederverwendbar-0.8.5.dist-info → wiederverwendbar-0.9.0.dist-info}/entry_points.txt +0 -0
@@ -1,47 +0,0 @@
1
- import uvicorn
2
- from starlette.applications import Starlette
3
- from starlette.responses import HTMLResponse
4
- from starlette.routing import Route
5
-
6
- from starlette_admin.contrib.mongoengine.admin import Admin
7
- from starlette_admin.contrib.mongoengine.view import ModelView
8
-
9
- from wiederverwendbar.examples.mongoengine.automatic_reference import Test1, Test2
10
- from wiederverwendbar.mongoengine import MongoengineDbSingleton
11
-
12
- # connect to database
13
- MongoengineDbSingleton(init=True)
14
-
15
- # Create starlette app
16
- app = Starlette(
17
- routes=[
18
- Route(
19
- "/",
20
- lambda r: HTMLResponse('<a href="/admin/">Click me to get to Admin!</a>'),
21
- ),
22
- ],
23
- )
24
-
25
- # Create admin
26
- admin = Admin(title="Test Admin")
27
-
28
-
29
-
30
- class Test1View(ModelView):
31
- def __init__(self):
32
- super().__init__(document=Test1, icon="fa fa-server", name="Test1", label="Test1")
33
-
34
- class Test2View(ModelView):
35
- def __init__(self):
36
- super().__init__(document=Test2, icon="fa fa-server", name="Test2", label="Test2")
37
-
38
-
39
- # Add views to admin
40
- admin.add_view(Test1View())
41
- admin.add_view(Test2View())
42
-
43
- # Mount admin to app
44
- admin.mount_to(app)
45
-
46
- if __name__ == '__main__':
47
- uvicorn.run(app, host="0.0.0.0", port=8000)
@@ -1,74 +0,0 @@
1
- from enum import Enum
2
-
3
- import uvicorn
4
- from starlette.applications import Starlette
5
- from starlette.responses import HTMLResponse
6
- from starlette.routing import Route
7
- from mongoengine import Document, EmbeddedDocument, StringField, IntField, FloatField, BooleanField, ListField, DictField, EmbeddedDocumentField, \
8
- GenericEmbeddedDocumentField
9
-
10
- from wiederverwendbar.mongoengine import MongoengineDbSingleton
11
- from wiederverwendbar.starlette_admin import GenericEmbeddedAdmin, GenericEmbeddedConverter, GenericEmbeddedDocumentView
12
-
13
- # connect to database
14
- MongoengineDbSingleton(init=True)
15
-
16
- # Create starlette app
17
- app = Starlette(
18
- routes=[
19
- Route(
20
- "/",
21
- lambda r: HTMLResponse('<a href="/admin/">Click me to get to Admin!</a>'),
22
- ),
23
- ],
24
- )
25
-
26
- # Create admin
27
- admin = GenericEmbeddedAdmin(title="Test Admin")
28
-
29
-
30
- class Test1(EmbeddedDocument):
31
- meta = {"name": "test1_qwe"}
32
-
33
- test_1_str = StringField()
34
- test_1_int = IntField()
35
- test_1_float = FloatField()
36
- test_1_bool = BooleanField()
37
-
38
-
39
- class Test2(EmbeddedDocument):
40
- test_2_str = StringField()
41
- test_2_int = IntField()
42
- test_2_float = FloatField()
43
- test_2_bool = BooleanField()
44
- test_2_list = ListField(StringField())
45
- test_2_dict = DictField()
46
-
47
-
48
- class TestEnum(Enum):
49
- A = "a"
50
- B = "b"
51
- C = "c"
52
-
53
-
54
- class Test(Document):
55
- meta = {"collection": "test"}
56
-
57
- test_emb = EmbeddedDocumentField(Test2)
58
- test_gen_emb = GenericEmbeddedDocumentField(choices=[Test1, Test2], help_text="Test Generic Embedded Document Field.")
59
- test_gen_emb_list = ListField(GenericEmbeddedDocumentField(choices=[Test1, Test2], help_text="Test Generic Embedded Document Field."))
60
-
61
-
62
- class TestView(GenericEmbeddedDocumentView):
63
- def __init__(self):
64
- super().__init__(document=Test, icon="fa fa-server", name="Test", label="Test", converter=GenericEmbeddedConverter())
65
-
66
-
67
- # Add views to admin#
68
- admin.add_view(TestView())
69
-
70
- # Mount admin to app
71
- admin.mount_to(app)
72
-
73
- if __name__ == '__main__':
74
- uvicorn.run(app, host="0.0.0.0", port=8000)
@@ -1,18 +0,0 @@
1
- from jinja2 import PackageLoader
2
-
3
- from wiederverwendbar.starlette_admin import MultiPathAdmin
4
-
5
-
6
- class TestAdmin1(MultiPathAdmin):
7
- static_files_packages = [("wiederverwendbar", "starlette_admin/statics")]
8
- template_packages = [PackageLoader("wiederverwendbar", "starlette_admin/mongoengine/generic_embedded_document_field")]
9
-
10
-
11
- class TestAdmin2(TestAdmin1):
12
- static_files_packages = [("wiederverwendbar", "starlette_admin/statics/js")]
13
- template_packages = [PackageLoader("wiederverwendbar", "starlette_admin/mongoengine/generic_embedded_document_field/templates")]
14
-
15
-
16
- base_admin = MultiPathAdmin(title="Test Admin")
17
- admin1 = TestAdmin1(title="Test Admin")
18
- admin2 = TestAdmin2(title="Test Admin")
@@ -1,55 +0,0 @@
1
- import logging
2
- import time
3
-
4
- from wiederverwendbar.task_manger import TaskManager, Task, AtCreation, EverySeconds
5
-
6
- logger = logging.getLogger(__name__)
7
- logger.setLevel(logging.DEBUG)
8
- ch = logging.StreamHandler()
9
- logger.addHandler(ch)
10
-
11
- # create manager
12
- manager1 = TaskManager(name="Manager1", logger=logger)
13
- manager2 = TaskManager(name="Manager2", logger=logger)
14
-
15
-
16
- @manager1.task(name="Task 1", trigger=AtCreation(delay_for_seconds=10))
17
- def task1():
18
- logger.debug("Task 1 ...")
19
-
20
-
21
- @manager1.task(name="Task 2", trigger=EverySeconds(2))
22
- def task2():
23
- logger.debug("Task 2 ...")
24
- time.sleep(2)
25
-
26
-
27
- @manager1.task(name="Task 3", trigger=EverySeconds(4))
28
- def task3():
29
- logger.debug("Task 3 ...")
30
- time.sleep(4)
31
-
32
-
33
- if __name__ == '__main__':
34
- logger.debug("This is the main module.")
35
-
36
- # start worker
37
- manager1.start()
38
- manager2.start()
39
-
40
- # create tasks
41
- Task(name="Task 1", manager=manager2, trigger=AtCreation(delay_for_seconds=10), payload=task1)
42
- Task(name="Task 2", manager=manager2, trigger=EverySeconds(2), payload=task2)
43
- Task(name="Task 3", manager=manager2, trigger=EverySeconds(4), payload=task3)
44
-
45
- # enter main loop
46
- try:
47
- while True:
48
- logger.debug("Main loop ...")
49
- # Manager().loop()
50
- time.sleep(1)
51
- except KeyboardInterrupt:
52
- logger.debug("Keyboard interrupt.")
53
-
54
- manager1.stop()
55
- manager2.stop()
@@ -1,14 +0,0 @@
1
- from pathlib import Path
2
-
3
- from wiederverwendbar.functions.test_file import test_file
4
-
5
- if __name__ == '__main__':
6
- generated_file = test_file(1, 'MB')
7
-
8
- # move the file to the current directory
9
- generated_file = generated_file.replace(Path(generated_file.name))
10
-
11
- input("Press any key to remove the generated file.")
12
-
13
- # remove the file
14
- generated_file.unlink()
@@ -1,15 +0,0 @@
1
- import typer
2
- from wiederverwendbar.typer import typer_resolve_defaults
3
-
4
- app = typer.Typer()
5
-
6
-
7
- @app.command()
8
- @typer_resolve_defaults
9
- def main(a: str, name: str = typer.Argument(default="World1"), qwe: str = typer.Option(default_factory=lambda: "qwe")):
10
- print(f"Hello {name}")
11
-
12
-
13
- if __name__ == "__main__":
14
- main(a="a1")
15
- app()
@@ -1,32 +0,0 @@
1
- import os
2
-
3
- from starlette.applications import Starlette
4
- from starlette.responses import HTMLResponse
5
- from starlette.routing import Route
6
-
7
- from wiederverwendbar.logger import LoggerSingleton, LoggerSettings
8
- from wiederverwendbar.singleton import Singleton
9
- from wiederverwendbar.uvicorn import UvicornServer
10
-
11
- init = False
12
- try:
13
- Singleton.get_by_type(LoggerSingleton)
14
- init = True
15
- except RuntimeError:
16
- ...
17
-
18
- if not init or __name__ == '__main__':
19
- LoggerSingleton(name="test", settings=LoggerSettings(log_level=LoggerSettings.LogLevels.DEBUG), init=True)
20
-
21
- app = Starlette(
22
- routes=[
23
- Route(
24
- "/",
25
- lambda r: HTMLResponse('<h1>Hello, world!</h1>'),
26
- ),
27
- ],
28
- )
29
-
30
- if __name__ == '__main__':
31
- UvicornServer("uvicorn_server:app", host="0.0.0.0", port=8000, workers=1)
32
- print()
@@ -1,10 +0,0 @@
1
- from enum import Enum
2
-
3
-
4
- class TerminalOutFiles(str, Enum):
5
- """
6
- Terminal output files
7
- """
8
-
9
- STDOUT = "stdout"
10
- STDERR = "stderr"