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.
- wiederverwendbar/__init__.py +8 -6
- wiederverwendbar/branding/__init__.py +1 -0
- wiederverwendbar/branding/settings.py +85 -0
- wiederverwendbar/console/__init__.py +3 -0
- wiederverwendbar/console/console.py +199 -0
- wiederverwendbar/console/out_files.py +19 -0
- wiederverwendbar/console/settings.py +9 -0
- wiederverwendbar/default.py +4 -1
- wiederverwendbar/fastapi/__init__.py +3 -0
- wiederverwendbar/fastapi/app.py +385 -0
- wiederverwendbar/fastapi/dependencies.py +11 -0
- wiederverwendbar/fastapi/settings.py +39 -0
- wiederverwendbar/functions/is_coroutine_function.py +19 -0
- wiederverwendbar/inspect.py +26 -0
- wiederverwendbar/logger/__init__.py +0 -1
- wiederverwendbar/logger/handlers/rich_console_handler.py +15 -6
- wiederverwendbar/logger/handlers/stream_console_handler.py +3 -16
- wiederverwendbar/logger/log_levels.py +4 -0
- wiederverwendbar/logger/settings.py +15 -20
- wiederverwendbar/pydantic/file_config.py +20 -4
- wiederverwendbar/rich/__init__.py +2 -0
- wiederverwendbar/rich/console.py +215 -0
- wiederverwendbar/rich/settings.py +26 -0
- wiederverwendbar/sqlalchemy/base.py +4 -4
- wiederverwendbar/task_manger/task.py +1 -4
- wiederverwendbar/task_manger/task_manager.py +14 -19
- wiederverwendbar/typer/__init__.py +3 -1
- wiederverwendbar/typer/app.py +172 -0
- wiederverwendbar/typer/settings.py +14 -0
- wiederverwendbar/warnings.py +6 -0
- {wiederverwendbar-0.8.5.dist-info → wiederverwendbar-0.9.0.dist-info}/METADATA +9 -6
- {wiederverwendbar-0.8.5.dist-info → wiederverwendbar-0.9.0.dist-info}/RECORD +34 -49
- wiederverwendbar/examples/__init__.py +0 -0
- wiederverwendbar/examples/before_after_wrap.py +0 -74
- wiederverwendbar/examples/colors.py +0 -16
- wiederverwendbar/examples/extended_thread.py +0 -28
- wiederverwendbar/examples/file_config.py +0 -11
- wiederverwendbar/examples/indexable_model.py +0 -19
- wiederverwendbar/examples/logger.py +0 -31
- wiederverwendbar/examples/logger_context/__init__.py +0 -0
- wiederverwendbar/examples/logger_context/example.py +0 -58
- wiederverwendbar/examples/logger_context/example_module.py +0 -13
- wiederverwendbar/examples/mongoengine/__init__.py +0 -0
- wiederverwendbar/examples/mongoengine/automatic_reference.py +0 -25
- wiederverwendbar/examples/mongoengine/db.py +0 -7
- wiederverwendbar/examples/mongoengine/log_streamer.py +0 -9
- wiederverwendbar/examples/mongoengine/logger.py +0 -25
- wiederverwendbar/examples/post_init.py +0 -29
- wiederverwendbar/examples/route.py +0 -12
- wiederverwendbar/examples/singletons.py +0 -59
- wiederverwendbar/examples/sqlalchemy/__init__.py +0 -0
- wiederverwendbar/examples/sqlalchemy/db.py +0 -89
- wiederverwendbar/examples/starlette_admin/__init__.py +0 -0
- wiederverwendbar/examples/starlette_admin/action_log.py +0 -126
- wiederverwendbar/examples/starlette_admin/action_log_file_download.py +0 -99
- wiederverwendbar/examples/starlette_admin/action_log_form.py +0 -149
- wiederverwendbar/examples/starlette_admin/action_log_thread.py +0 -192
- wiederverwendbar/examples/starlette_admin/automatic_reference_admin.py +0 -47
- wiederverwendbar/examples/starlette_admin/generic_embedded_document_field.py +0 -74
- wiederverwendbar/examples/starlette_admin/multi_path_admin.py +0 -18
- wiederverwendbar/examples/task_manager.py +0 -55
- wiederverwendbar/examples/test_file.py +0 -14
- wiederverwendbar/examples/typer_resolve_defaults.py +0 -15
- wiederverwendbar/examples/uvicorn_server.py +0 -32
- wiederverwendbar/logger/terminal_out_files.py +0 -10
- {wiederverwendbar-0.8.5.dist-info → wiederverwendbar-0.9.0.dist-info}/WHEEL +0 -0
- {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()
|
File without changes
|
File without changes
|