amsdal 0.4.13__cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.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 (269) hide show
  1. amsdal/Third-Party Materials - AMSDAL Dependencies - License Notices.md +1334 -0
  2. amsdal/__about__.py +4 -0
  3. amsdal/__about__.pyi +1 -0
  4. amsdal/__init__.py +23 -0
  5. amsdal/__init__.pyi +9 -0
  6. amsdal/__migrations__/0000_initial.py +217 -0
  7. amsdal/__migrations__/0001_datetime_type.py +18 -0
  8. amsdal/__migrations__/0002_fixture_order.py +44 -0
  9. amsdal/__migrations__/0003_schema_type_in_class_meta.py +44 -0
  10. amsdal/cloud/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  11. amsdal/cloud/__init__.pyi +0 -0
  12. amsdal/cloud/client.cpython-312-x86_64-linux-gnu.so +0 -0
  13. amsdal/cloud/client.pyi +57 -0
  14. amsdal/cloud/constants.cpython-312-x86_64-linux-gnu.so +0 -0
  15. amsdal/cloud/constants.pyi +13 -0
  16. amsdal/cloud/enums.cpython-312-x86_64-linux-gnu.so +0 -0
  17. amsdal/cloud/enums.pyi +68 -0
  18. amsdal/cloud/models/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  19. amsdal/cloud/models/__init__.pyi +0 -0
  20. amsdal/cloud/models/base.cpython-312-x86_64-linux-gnu.so +0 -0
  21. amsdal/cloud/models/base.pyi +247 -0
  22. amsdal/cloud/services/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  23. amsdal/cloud/services/__init__.pyi +0 -0
  24. amsdal/cloud/services/actions/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  25. amsdal/cloud/services/actions/__init__.pyi +0 -0
  26. amsdal/cloud/services/actions/add_allowlist_ip.cpython-312-x86_64-linux-gnu.so +0 -0
  27. amsdal/cloud/services/actions/add_allowlist_ip.pyi +19 -0
  28. amsdal/cloud/services/actions/add_basic_auth.cpython-312-x86_64-linux-gnu.so +0 -0
  29. amsdal/cloud/services/actions/add_basic_auth.pyi +21 -0
  30. amsdal/cloud/services/actions/add_dependency.cpython-312-x86_64-linux-gnu.so +0 -0
  31. amsdal/cloud/services/actions/add_dependency.pyi +19 -0
  32. amsdal/cloud/services/actions/add_secret.cpython-312-x86_64-linux-gnu.so +0 -0
  33. amsdal/cloud/services/actions/add_secret.pyi +20 -0
  34. amsdal/cloud/services/actions/base.cpython-312-x86_64-linux-gnu.so +0 -0
  35. amsdal/cloud/services/actions/base.pyi +122 -0
  36. amsdal/cloud/services/actions/create_deploy.cpython-312-x86_64-linux-gnu.so +0 -0
  37. amsdal/cloud/services/actions/create_deploy.pyi +41 -0
  38. amsdal/cloud/services/actions/create_env.cpython-312-x86_64-linux-gnu.so +0 -0
  39. amsdal/cloud/services/actions/create_env.pyi +19 -0
  40. amsdal/cloud/services/actions/create_session.cpython-312-x86_64-linux-gnu.so +0 -0
  41. amsdal/cloud/services/actions/create_session.pyi +17 -0
  42. amsdal/cloud/services/actions/delete_allowlist_ip.cpython-312-x86_64-linux-gnu.so +0 -0
  43. amsdal/cloud/services/actions/delete_allowlist_ip.pyi +19 -0
  44. amsdal/cloud/services/actions/delete_basic_auth.cpython-312-x86_64-linux-gnu.so +0 -0
  45. amsdal/cloud/services/actions/delete_basic_auth.pyi +20 -0
  46. amsdal/cloud/services/actions/delete_dependency.cpython-312-x86_64-linux-gnu.so +0 -0
  47. amsdal/cloud/services/actions/delete_dependency.pyi +21 -0
  48. amsdal/cloud/services/actions/delete_env.cpython-312-x86_64-linux-gnu.so +0 -0
  49. amsdal/cloud/services/actions/delete_env.pyi +21 -0
  50. amsdal/cloud/services/actions/delete_secret.cpython-312-x86_64-linux-gnu.so +0 -0
  51. amsdal/cloud/services/actions/delete_secret.pyi +21 -0
  52. amsdal/cloud/services/actions/destroy_deploy.cpython-312-x86_64-linux-gnu.so +0 -0
  53. amsdal/cloud/services/actions/destroy_deploy.pyi +18 -0
  54. amsdal/cloud/services/actions/expose_db.cpython-312-x86_64-linux-gnu.so +0 -0
  55. amsdal/cloud/services/actions/expose_db.pyi +22 -0
  56. amsdal/cloud/services/actions/get_basic_auth_credentials.cpython-312-x86_64-linux-gnu.so +0 -0
  57. amsdal/cloud/services/actions/get_basic_auth_credentials.pyi +21 -0
  58. amsdal/cloud/services/actions/get_monitoring_info.cpython-312-x86_64-linux-gnu.so +0 -0
  59. amsdal/cloud/services/actions/get_monitoring_info.pyi +21 -0
  60. amsdal/cloud/services/actions/list_dependencies.cpython-312-x86_64-linux-gnu.so +0 -0
  61. amsdal/cloud/services/actions/list_dependencies.pyi +21 -0
  62. amsdal/cloud/services/actions/list_deploys.cpython-312-x86_64-linux-gnu.so +0 -0
  63. amsdal/cloud/services/actions/list_deploys.pyi +19 -0
  64. amsdal/cloud/services/actions/list_envs.cpython-312-x86_64-linux-gnu.so +0 -0
  65. amsdal/cloud/services/actions/list_envs.pyi +20 -0
  66. amsdal/cloud/services/actions/list_secrets.cpython-312-x86_64-linux-gnu.so +0 -0
  67. amsdal/cloud/services/actions/list_secrets.pyi +22 -0
  68. amsdal/cloud/services/actions/manager.cpython-312-x86_64-linux-gnu.so +0 -0
  69. amsdal/cloud/services/actions/manager.pyi +278 -0
  70. amsdal/cloud/services/actions/signup_action.cpython-312-x86_64-linux-gnu.so +0 -0
  71. amsdal/cloud/services/actions/signup_action.pyi +20 -0
  72. amsdal/cloud/services/actions/update_deploy.cpython-312-x86_64-linux-gnu.so +0 -0
  73. amsdal/cloud/services/actions/update_deploy.pyi +19 -0
  74. amsdal/cloud/services/auth/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  75. amsdal/cloud/services/auth/__init__.pyi +0 -0
  76. amsdal/cloud/services/auth/base.cpython-312-x86_64-linux-gnu.so +0 -0
  77. amsdal/cloud/services/auth/base.pyi +6 -0
  78. amsdal/cloud/services/auth/credentials.cpython-312-x86_64-linux-gnu.so +0 -0
  79. amsdal/cloud/services/auth/credentials.pyi +30 -0
  80. amsdal/cloud/services/auth/manager.cpython-312-x86_64-linux-gnu.so +0 -0
  81. amsdal/cloud/services/auth/manager.pyi +26 -0
  82. amsdal/cloud/services/auth/signup_service.cpython-312-x86_64-linux-gnu.so +0 -0
  83. amsdal/cloud/services/auth/signup_service.pyi +32 -0
  84. amsdal/cloud/services/auth/token.cpython-312-x86_64-linux-gnu.so +0 -0
  85. amsdal/cloud/services/auth/token.pyi +27 -0
  86. amsdal/configs/__init__.py +0 -0
  87. amsdal/configs/__init__.pyi +0 -0
  88. amsdal/configs/constants.py +33 -0
  89. amsdal/configs/constants.pyi +22 -0
  90. amsdal/configs/main.py +258 -0
  91. amsdal/configs/main.pyi +173 -0
  92. amsdal/context/__init__.py +0 -0
  93. amsdal/context/__init__.pyi +0 -0
  94. amsdal/context/manager.py +69 -0
  95. amsdal/context/manager.pyi +50 -0
  96. amsdal/contrib/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  97. amsdal/contrib/__init__.pyi +0 -0
  98. amsdal/contrib/app_config.py +7 -0
  99. amsdal/contrib/app_config.pyi +6 -0
  100. amsdal/contrib/auth/__init__.py +0 -0
  101. amsdal/contrib/auth/__init__.pyi +0 -0
  102. amsdal/contrib/auth/app.py +27 -0
  103. amsdal/contrib/auth/app.pyi +15 -0
  104. amsdal/contrib/auth/decorators/__init__.py +35 -0
  105. amsdal/contrib/auth/decorators/__init__.pyi +6 -0
  106. amsdal/contrib/auth/errors.py +7 -0
  107. amsdal/contrib/auth/errors.pyi +4 -0
  108. amsdal/contrib/auth/fixtures/basic_permissions.json +64 -0
  109. amsdal/contrib/auth/lifecycle/__init__.py +0 -0
  110. amsdal/contrib/auth/lifecycle/__init__.pyi +0 -0
  111. amsdal/contrib/auth/lifecycle/consumer.py +394 -0
  112. amsdal/contrib/auth/lifecycle/consumer.pyi +108 -0
  113. amsdal/contrib/auth/migrations/0000_initial.py +84 -0
  114. amsdal/contrib/auth/models/__init__.py +0 -0
  115. amsdal/contrib/auth/models/__init__.pyi +0 -0
  116. amsdal/contrib/auth/models/login_session.py +118 -0
  117. amsdal/contrib/auth/models/login_session.pyi +37 -0
  118. amsdal/contrib/auth/models/permission.py +23 -0
  119. amsdal/contrib/auth/models/permission.pyi +18 -0
  120. amsdal/contrib/auth/models/user.py +106 -0
  121. amsdal/contrib/auth/models/user.pyi +46 -0
  122. amsdal/contrib/auth/settings.py +36 -0
  123. amsdal/contrib/auth/settings.pyi +26 -0
  124. amsdal/contrib/frontend_configs/__init__.py +0 -0
  125. amsdal/contrib/frontend_configs/__init__.pyi +0 -0
  126. amsdal/contrib/frontend_configs/app.py +24 -0
  127. amsdal/contrib/frontend_configs/app.pyi +19 -0
  128. amsdal/contrib/frontend_configs/constants.py +1 -0
  129. amsdal/contrib/frontend_configs/constants.pyi +1 -0
  130. amsdal/contrib/frontend_configs/conversion/__init__.py +5 -0
  131. amsdal/contrib/frontend_configs/conversion/__init__.pyi +3 -0
  132. amsdal/contrib/frontend_configs/conversion/convert.py +286 -0
  133. amsdal/contrib/frontend_configs/conversion/convert.pyi +22 -0
  134. amsdal/contrib/frontend_configs/lifecycle/__init__.py +0 -0
  135. amsdal/contrib/frontend_configs/lifecycle/__init__.pyi +0 -0
  136. amsdal/contrib/frontend_configs/lifecycle/consumer.py +306 -0
  137. amsdal/contrib/frontend_configs/lifecycle/consumer.pyi +98 -0
  138. amsdal/contrib/frontend_configs/migrations/0000_initial.py +256 -0
  139. amsdal/contrib/frontend_configs/models/__init__.py +0 -0
  140. amsdal/contrib/frontend_configs/models/__init__.pyi +0 -0
  141. amsdal/contrib/frontend_configs/models/frontend_activator_config.py +22 -0
  142. amsdal/contrib/frontend_configs/models/frontend_activator_config.pyi +12 -0
  143. amsdal/contrib/frontend_configs/models/frontend_config_async_validator.py +11 -0
  144. amsdal/contrib/frontend_configs/models/frontend_config_async_validator.pyi +7 -0
  145. amsdal/contrib/frontend_configs/models/frontend_config_control_action.py +54 -0
  146. amsdal/contrib/frontend_configs/models/frontend_config_control_action.pyi +32 -0
  147. amsdal/contrib/frontend_configs/models/frontend_config_group_validator.py +21 -0
  148. amsdal/contrib/frontend_configs/models/frontend_config_group_validator.pyi +11 -0
  149. amsdal/contrib/frontend_configs/models/frontend_config_option.py +12 -0
  150. amsdal/contrib/frontend_configs/models/frontend_config_option.pyi +8 -0
  151. amsdal/contrib/frontend_configs/models/frontend_config_skip_none_base.py +17 -0
  152. amsdal/contrib/frontend_configs/models/frontend_config_skip_none_base.pyi +8 -0
  153. amsdal/contrib/frontend_configs/models/frontend_config_slider_option.py +13 -0
  154. amsdal/contrib/frontend_configs/models/frontend_config_slider_option.pyi +9 -0
  155. amsdal/contrib/frontend_configs/models/frontend_config_text_mask.py +14 -0
  156. amsdal/contrib/frontend_configs/models/frontend_config_text_mask.pyi +10 -0
  157. amsdal/contrib/frontend_configs/models/frontend_config_validator.py +28 -0
  158. amsdal/contrib/frontend_configs/models/frontend_config_validator.pyi +15 -0
  159. amsdal/contrib/frontend_configs/models/frontend_control_config.py +87 -0
  160. amsdal/contrib/frontend_configs/models/frontend_control_config.pyi +35 -0
  161. amsdal/contrib/frontend_configs/models/frontend_model_config.py +14 -0
  162. amsdal/contrib/frontend_configs/models/frontend_model_config.pyi +9 -0
  163. amsdal/contrib/frontend_configs/utils.py +29 -0
  164. amsdal/contrib/frontend_configs/utils.pyi +17 -0
  165. amsdal/errors.py +31 -0
  166. amsdal/errors.pyi +12 -0
  167. amsdal/fixtures/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  168. amsdal/fixtures/__init__.pyi +0 -0
  169. amsdal/fixtures/manager.cpython-312-x86_64-linux-gnu.so +0 -0
  170. amsdal/fixtures/manager.pyi +170 -0
  171. amsdal/fixtures/utils.cpython-312-x86_64-linux-gnu.so +0 -0
  172. amsdal/fixtures/utils.pyi +9 -0
  173. amsdal/manager.cpython-312-x86_64-linux-gnu.so +0 -0
  174. amsdal/manager.pyi +265 -0
  175. amsdal/mixins/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  176. amsdal/mixins/__init__.pyi +0 -0
  177. amsdal/mixins/class_versions_mixin.cpython-312-x86_64-linux-gnu.so +0 -0
  178. amsdal/mixins/class_versions_mixin.pyi +12 -0
  179. amsdal/models/__init__.py +19 -0
  180. amsdal/models/__init__.pyi +9 -0
  181. amsdal/models/core/__init__.py +0 -0
  182. amsdal/models/core/__init__.pyi +0 -0
  183. amsdal/models/core/class_object.py +37 -0
  184. amsdal/models/core/class_object.pyi +24 -0
  185. amsdal/models/core/class_object_meta.py +26 -0
  186. amsdal/models/core/class_object_meta.pyi +15 -0
  187. amsdal/models/core/class_property.py +20 -0
  188. amsdal/models/core/class_property.pyi +11 -0
  189. amsdal/models/core/class_property_meta.py +15 -0
  190. amsdal/models/core/class_property_meta.pyi +10 -0
  191. amsdal/models/core/file.py +156 -0
  192. amsdal/models/core/file.pyi +104 -0
  193. amsdal/models/core/fixture.py +25 -0
  194. amsdal/models/core/fixture.pyi +14 -0
  195. amsdal/models/core/option.py +11 -0
  196. amsdal/models/core/option.pyi +8 -0
  197. amsdal/models/core/validator.py +12 -0
  198. amsdal/models/core/validator.pyi +8 -0
  199. amsdal/models/types/__init__.py +0 -0
  200. amsdal/models/types/__init__.pyi +0 -0
  201. amsdal/models/types/object.py +26 -0
  202. amsdal/models/types/object.pyi +16 -0
  203. amsdal/py.typed +0 -0
  204. amsdal/queryset/__init__.py +21 -0
  205. amsdal/queryset/__init__.pyi +6 -0
  206. amsdal/schemas/__init__.py +0 -0
  207. amsdal/schemas/__init__.pyi +0 -0
  208. amsdal/schemas/core/class_object/model.json +31 -0
  209. amsdal/schemas/core/class_object/properties/display_name.py +9 -0
  210. amsdal/schemas/core/class_object_meta/model.json +59 -0
  211. amsdal/schemas/core/class_property/model.json +22 -0
  212. amsdal/schemas/core/class_property_meta/model.json +23 -0
  213. amsdal/schemas/core/file/hooks/pre_create.py +24 -0
  214. amsdal/schemas/core/file/hooks/pre_update.py +24 -0
  215. amsdal/schemas/core/file/model.json +23 -0
  216. amsdal/schemas/core/file/properties/from_file.py +34 -0
  217. amsdal/schemas/core/file/properties/mimetype.py +13 -0
  218. amsdal/schemas/core/file/properties/str.py +6 -0
  219. amsdal/schemas/core/file/properties/to_file.py +24 -0
  220. amsdal/schemas/core/file/properties/validate_data.py +32 -0
  221. amsdal/schemas/core/fixture/model.json +35 -0
  222. amsdal/schemas/core/option/model.json +19 -0
  223. amsdal/schemas/core/validator/model.json +19 -0
  224. amsdal/schemas/interfaces.py +25 -0
  225. amsdal/schemas/interfaces.pyi +20 -0
  226. amsdal/schemas/manager.cpython-312-x86_64-linux-gnu.so +0 -0
  227. amsdal/schemas/manager.py +0 -0
  228. amsdal/schemas/manager.pyi +0 -0
  229. amsdal/schemas/mixins/__init__.py +0 -0
  230. amsdal/schemas/mixins/__init__.pyi +0 -0
  231. amsdal/schemas/mixins/check_dependencies_mixin.py +125 -0
  232. amsdal/schemas/mixins/check_dependencies_mixin.pyi +45 -0
  233. amsdal/schemas/mixins/verify_schemas_mixin.py +96 -0
  234. amsdal/schemas/mixins/verify_schemas_mixin.pyi +33 -0
  235. amsdal/schemas/repository.py +84 -0
  236. amsdal/schemas/repository.pyi +22 -0
  237. amsdal/schemas/types/anything/model.json +7 -0
  238. amsdal/schemas/types/array/model.json +7 -0
  239. amsdal/schemas/types/binary/model.json +7 -0
  240. amsdal/schemas/types/boolean/model.json +17 -0
  241. amsdal/schemas/types/date/model.json +7 -0
  242. amsdal/schemas/types/datetime/model.json +7 -0
  243. amsdal/schemas/types/dictionary/model.json +8 -0
  244. amsdal/schemas/types/number/model.json +8 -0
  245. amsdal/schemas/types/object/model.json +53 -0
  246. amsdal/schemas/types/string/model.json +8 -0
  247. amsdal/schemas/utils.py +16 -0
  248. amsdal/schemas/utils.pyi +10 -0
  249. amsdal/services/__init__.cpython-312-x86_64-linux-gnu.so +0 -0
  250. amsdal/services/__init__.pyi +0 -0
  251. amsdal/services/transaction_execution.cpython-312-x86_64-linux-gnu.so +0 -0
  252. amsdal/services/transaction_execution.pyi +93 -0
  253. amsdal/transactions/__init__.py +13 -0
  254. amsdal/transactions/__init__.pyi +4 -0
  255. amsdal/utils/__init__.py +0 -0
  256. amsdal/utils/__init__.pyi +0 -0
  257. amsdal/utils/contrib_paths.py +23 -0
  258. amsdal/utils/contrib_paths.pyi +14 -0
  259. amsdal/utils/rollback/__init__.py +440 -0
  260. amsdal/utils/rollback/__init__.pyi +38 -0
  261. amsdal/utils/tests/__init__.py +0 -0
  262. amsdal/utils/tests/enums.py +18 -0
  263. amsdal/utils/tests/factories.py +49 -0
  264. amsdal/utils/tests/helpers.py +499 -0
  265. amsdal-0.4.13.dist-info/METADATA +369 -0
  266. amsdal-0.4.13.dist-info/RECORD +269 -0
  267. amsdal-0.4.13.dist-info/WHEEL +6 -0
  268. amsdal-0.4.13.dist-info/licenses/LICENSE.txt +107 -0
  269. amsdal-0.4.13.dist-info/top_level.txt +1 -0
amsdal/manager.pyi ADDED
@@ -0,0 +1,265 @@
1
+ from _typeshed import Incomplete
2
+ from amsdal.cloud.services.actions.manager import CloudActionsManager as CloudActionsManager
3
+ from amsdal.cloud.services.auth.signup_service import SignupService as SignupService
4
+ from amsdal.configs.main import settings as settings
5
+ from amsdal.errors import AmsdalAuthenticationError as AmsdalAuthenticationError, AmsdalMissingCredentialsError as AmsdalMissingCredentialsError, AmsdalRuntimeError as AmsdalRuntimeError, AmsdalSignupError as AmsdalSignupError
6
+ from amsdal.fixtures.manager import AsyncFixturesManager as AsyncFixturesManager, FixturesManager as FixturesManager
7
+ from amsdal.mixins.class_versions_mixin import ClassVersionsMixin as ClassVersionsMixin
8
+ from amsdal_data.transactions.decorators import async_transaction, transaction
9
+ from amsdal_models.classes.class_manager import ClassManager
10
+ from amsdal_utils.config.data_models.amsdal_config import AmsdalConfig as AmsdalConfig
11
+ from amsdal_utils.utils.singleton import Singleton
12
+
13
+ class AmsdalManager(ClassVersionsMixin, metaclass=Singleton):
14
+ """
15
+ Manages the AMSDAL framework components and operations.
16
+
17
+ This class is responsible for initializing, setting up, and managing various components
18
+ of the AMSDAL framework, including connections, data management, schema management,
19
+ and authentication. It also provides methods for building and tearing down the framework.
20
+ """
21
+ _class_manager: ClassManager
22
+ _config_manager: Incomplete
23
+ _config: Incomplete
24
+ _data_application: Incomplete
25
+ _is_setup: bool
26
+ __is_authenticated: bool
27
+ _metadata_manager: Incomplete
28
+ _auth_manager: Incomplete
29
+ def __init__(self, *, raise_on_new_signup: bool = False) -> None:
30
+ """
31
+ Initializes all sub managers. Reads the configuration.
32
+
33
+ Returns:
34
+ None
35
+ """
36
+ @property
37
+ def is_setup(self) -> bool: ...
38
+ @property
39
+ def is_authenticated(self) -> bool:
40
+ """
41
+ Indicates if the AMSDAL license authentication process has been passed.
42
+
43
+ This property returns a boolean value indicating whether the AMSDAL license
44
+ authentication process has been successfully completed.
45
+
46
+ Returns:
47
+ bool: True if authenticated, False otherwise.
48
+ """
49
+ def pre_setup(self) -> None:
50
+ """
51
+ Initiates models root path and adds it into sys.path.
52
+
53
+ This method initializes the class manager models modules and sets up the models root path
54
+ as specified in the settings. It ensures that the models root path is added
55
+ to the system path for proper module resolution.
56
+
57
+ Returns:
58
+ None
59
+ """
60
+ def setup(self) -> None:
61
+ """
62
+ Initiates models root path and the connections.
63
+
64
+ This method sets up the AMSDAL framework by initializing the models root path and
65
+ establishing connections. It ensures that the setup process is only performed once.
66
+
67
+ Raises:
68
+ AmsdalRuntimeError: If the AMSDAL manager is already set up.
69
+
70
+ Returns:
71
+ None
72
+ """
73
+ @transaction
74
+ def post_setup(self) -> None:
75
+ """
76
+ Registers internal classes and prepares connections (creates internal tables).
77
+ """
78
+ def _check_auth(self) -> None: ...
79
+ @property
80
+ def cloud_actions_manager(self) -> CloudActionsManager:
81
+ """
82
+ Provides access to the CloudActionsManager.
83
+
84
+ This property checks if the AMSDAL manager is authenticated and then returns
85
+ an instance of the CloudActionsManager.
86
+
87
+ Returns:
88
+ CloudActionsManager: An instance of the CloudActionsManager.
89
+
90
+ Raises:
91
+ AmsdalAuthenticationError: If the AMSDAL manager is not authenticated.
92
+ """
93
+ def authenticate(self) -> None:
94
+ """
95
+ Run AMSDAL license authentication process.
96
+
97
+ This method runs the AMSDAL license authentication process and sets the
98
+ authentication status accordingly.
99
+
100
+ Returns:
101
+ None
102
+ """
103
+ @transaction
104
+ def apply_fixtures(self) -> None:
105
+ """
106
+ Loads and applies fixtures defined in your application.
107
+
108
+ This method loads the fixtures from the specified path and applies them to the
109
+ AMSDAL framework. It uses the `FixturesManager` to manage the loading and application
110
+ of the fixtures.
111
+
112
+ Returns:
113
+ None
114
+ """
115
+ def init_classes(self) -> None:
116
+ """
117
+ Initializes and imports classes based on the schema manager's class schemas.
118
+
119
+ This method iterates over the class schemas provided by the schema manager and imports
120
+ the classes into the class manager, excluding those of type `SchemaTypes.TYPE`.
121
+
122
+ Returns:
123
+ None
124
+ """
125
+ def teardown(self) -> None:
126
+ """
127
+ Clean up everything on the application exit.
128
+
129
+ This method performs a cleanup of all components managed by the AMSDAL framework
130
+ when the application exits. It disconnects and invalidates connections, clears caches,
131
+ and resets the setup status.
132
+
133
+ Raises:
134
+ AmsdalRuntimeError: If the AMSDAL manager is not set up.
135
+
136
+ Returns:
137
+ None
138
+ """
139
+
140
+ class AsyncAmsdalManager(ClassVersionsMixin, metaclass=Singleton):
141
+ """
142
+ Manages the AMSDAL framework components and operations.
143
+
144
+ This class is responsible for initializing, setting up, and managing various components
145
+ of the AMSDAL framework, including connections, data management, schema management,
146
+ and authentication. It also provides methods for building and tearing down the framework.
147
+ """
148
+ _class_manager: ClassManager
149
+ _config_manager: Incomplete
150
+ _config: Incomplete
151
+ _data_application: Incomplete
152
+ _is_setup: bool
153
+ __is_authenticated: bool
154
+ _metadata_manager: Incomplete
155
+ _auth_manager: Incomplete
156
+ def __init__(self, *, raise_on_new_signup: bool = False) -> None:
157
+ """
158
+ Initializes all sub managers. Reads the configuration.
159
+
160
+ Returns:
161
+ None
162
+ """
163
+ @property
164
+ def is_setup(self) -> bool: ...
165
+ @property
166
+ def is_authenticated(self) -> bool:
167
+ """
168
+ Indicates if the AMSDAL license authentication process has been passed.
169
+
170
+ This property returns a boolean value indicating whether the AMSDAL license
171
+ authentication process has been successfully completed.
172
+
173
+ Returns:
174
+ bool: True if authenticated, False otherwise.
175
+ """
176
+ def pre_setup(self) -> None:
177
+ """
178
+ Initiates models root path and adds it into sys.path.
179
+
180
+ This method initializes the class manager and sets up the models root path
181
+ as specified in the settings. It ensures that the models root path is added
182
+ to the system path for proper module resolution.
183
+
184
+ Returns:
185
+ None
186
+ """
187
+ async def setup(self) -> None:
188
+ """
189
+ Initiates models root path and the connections.
190
+
191
+ This method sets up the AMSDAL framework by initializing the models root path and
192
+ establishing connections. It ensures that the setup process is only performed once.
193
+
194
+ Raises:
195
+ AmsdalRuntimeError: If the AMSDAL manager is already set up.
196
+
197
+ Returns:
198
+ None
199
+ """
200
+ @async_transaction
201
+ async def post_setup(self) -> None:
202
+ """
203
+ Registers internal classes and prepares connections (creates internal tables).
204
+ """
205
+ def _check_auth(self) -> None: ...
206
+ @property
207
+ def cloud_actions_manager(self) -> CloudActionsManager:
208
+ """
209
+ Provides access to the CloudActionsManager.
210
+
211
+ This property checks if the AMSDAL manager is authenticated and then returns
212
+ an instance of the CloudActionsManager.
213
+
214
+ Returns:
215
+ CloudActionsManager: An instance of the CloudActionsManager.
216
+
217
+ Raises:
218
+ AmsdalAuthenticationError: If the AMSDAL manager is not authenticated.
219
+ """
220
+ def authenticate(self) -> None:
221
+ """
222
+ Run AMSDAL license authentication process.
223
+
224
+ This method runs the AMSDAL license authentication process and sets the
225
+ authentication status accordingly.
226
+
227
+ Returns:
228
+ None
229
+ """
230
+ @async_transaction
231
+ async def apply_fixtures(self) -> None:
232
+ """
233
+ Loads and applies fixtures defined in your application.
234
+
235
+ This method loads the fixtures from the specified path and applies them to the
236
+ AMSDAL framework. It uses the `FixturesManager` to manage the loading and application
237
+ of the fixtures.
238
+
239
+ Returns:
240
+ None
241
+ """
242
+ def init_classes(self) -> None:
243
+ """
244
+ Initializes and imports classes based on the schema manager's class schemas.
245
+
246
+ This method iterates over the class schemas provided by the schema manager and imports
247
+ the classes into the class manager, excluding those of type `SchemaTypes.TYPE`.
248
+
249
+ Returns:
250
+ None
251
+ """
252
+ async def teardown(self) -> None:
253
+ """
254
+ Clean up everything on the application exit.
255
+
256
+ This method performs a cleanup of all components managed by the AMSDAL framework
257
+ when the application exits. It disconnects and invalidates connections, clears caches,
258
+ and resets the setup status.
259
+
260
+ Raises:
261
+ AmsdalRuntimeError: If the AMSDAL manager is not set up.
262
+
263
+ Returns:
264
+ None
265
+ """
File without changes
@@ -0,0 +1,12 @@
1
+ from amsdal_data.connections.historical.schema_version_manager import AsyncHistoricalSchemaVersionManager, HistoricalSchemaVersionManager
2
+
3
+ class ClassVersionsMixin:
4
+ """
5
+ Mixin class to manage class versions and related table schemas.
6
+ """
7
+ @staticmethod
8
+ def _register_internal_classes(schema_version_manager: HistoricalSchemaVersionManager | AsyncHistoricalSchemaVersionManager) -> None: ...
9
+ @classmethod
10
+ def register_internal_classes(cls) -> None: ...
11
+ @classmethod
12
+ def aregister_internal_classes(cls) -> None: ...
@@ -0,0 +1,19 @@
1
+ from amsdal_models.builder.validators.dict_validators import validate_non_empty_keys
2
+ from amsdal_models.builder.validators.options_validators import validate_options
3
+ from amsdal_models.classes.data_models.constraints import UniqueConstraint
4
+ from amsdal_models.classes.data_models.indexes import IndexInfo
5
+ from amsdal_models.classes.model import Model
6
+ from amsdal_models.classes.model import TypeModel
7
+ from amsdal_models.classes.relationships.many_reference_field import ManyReferenceField
8
+ from amsdal_models.classes.relationships.reference_field import ReferenceField
9
+
10
+ __all__ = [
11
+ 'IndexInfo',
12
+ 'ManyReferenceField',
13
+ 'Model',
14
+ 'ReferenceField',
15
+ 'TypeModel',
16
+ 'UniqueConstraint',
17
+ 'validate_non_empty_keys',
18
+ 'validate_options',
19
+ ]
@@ -0,0 +1,9 @@
1
+ from amsdal_models.builder.validators.dict_validators import validate_non_empty_keys as validate_non_empty_keys
2
+ from amsdal_models.builder.validators.options_validators import validate_options as validate_options
3
+ from amsdal_models.classes.data_models.constraints import UniqueConstraint as UniqueConstraint
4
+ from amsdal_models.classes.data_models.indexes import IndexInfo as IndexInfo
5
+ from amsdal_models.classes.model import Model as Model, TypeModel as TypeModel
6
+ from amsdal_models.classes.relationships.many_reference_field import ManyReferenceField as ManyReferenceField
7
+ from amsdal_models.classes.relationships.reference_field import ReferenceField as ReferenceField
8
+
9
+ __all__ = ['IndexInfo', 'ManyReferenceField', 'Model', 'ReferenceField', 'TypeModel', 'UniqueConstraint', 'validate_non_empty_keys', 'validate_options']
File without changes
File without changes
@@ -0,0 +1,37 @@
1
+ from typing import Any
2
+ from typing import ClassVar
3
+ from typing import Optional
4
+
5
+ from amsdal_models.builder.validators.dict_validators import validate_non_empty_keys
6
+ from amsdal_models.classes.model import Model
7
+ from amsdal_utils.models.enums import ModuleType
8
+ from pydantic.fields import Field
9
+ from pydantic.functional_validators import field_validator
10
+
11
+ from amsdal.models.core.class_property import * # noqa: F403
12
+
13
+
14
+ class ClassObject(Model):
15
+ __module_type__: ClassVar[ModuleType] = ModuleType.CORE
16
+ properties: Optional[dict[str, Optional['ClassProperty']]] = Field(None, title='Properties') # noqa: F405, UP007
17
+ table_name: Optional[str] = Field(None, title='Table name') # noqa: UP007
18
+ primary_key: Optional[list[str]] = Field(None, title='Primary key fields') # noqa: UP007
19
+ indexed: Optional[list[str]] = Field(None, title='Indexed') # noqa: UP007
20
+ unique: Optional[list[list[str]]] = Field(None, title='Unique Fields') # noqa: UP007
21
+ required: Optional[list[str]] = Field(None, title='Required') # noqa: UP007
22
+ meta_class: Optional[str] = Field('ClassObject', title='Meta Class') # noqa: UP007
23
+
24
+ @field_validator('properties')
25
+ @classmethod
26
+ def _non_empty_keys_properties(cls: type, value: Any) -> Any:
27
+ return validate_non_empty_keys(value)
28
+
29
+ @property
30
+ def display_name(self) -> str:
31
+ """
32
+ Returns the display name of the object.
33
+
34
+ Returns:
35
+ str: The display name, which is the title of the object.
36
+ """
37
+ return self.title
@@ -0,0 +1,24 @@
1
+ from amsdal.models.core.class_property import *
2
+ from amsdal_models.classes.model import Model
3
+ from amsdal_utils.models.enums import ModuleType
4
+ from typing import Any, ClassVar
5
+
6
+ class ClassObject(Model):
7
+ __module_type__: ClassVar[ModuleType] = ...
8
+ properties: dict[str, ClassProperty | None] | None = ...
9
+ table_name: str | None = ...
10
+ primary_key: list[str] | None = ...
11
+ indexed: list[str] | None = ...
12
+ unique: list[list[str]] | None = ...
13
+ required: list[str] | None = ...
14
+ meta_class: str | None = ...
15
+ @classmethod
16
+ def _non_empty_keys_properties(cls, value: Any) -> Any: ...
17
+ @property
18
+ def display_name(self) -> str:
19
+ """
20
+ Returns the display name of the object.
21
+
22
+ Returns:
23
+ str: The display name, which is the title of the object.
24
+ """
@@ -0,0 +1,26 @@
1
+ from typing import Any
2
+ from typing import ClassVar
3
+ from typing import Optional
4
+
5
+ from amsdal_models.builder.validators.dict_validators import validate_non_empty_keys
6
+ from amsdal_models.classes.model import Model
7
+ from amsdal_utils.models.enums import ModuleType
8
+ from pydantic.fields import Field
9
+ from pydantic.functional_validators import field_validator
10
+
11
+ from amsdal.models.core.class_property_meta import * # noqa: F403
12
+
13
+
14
+ class ClassObjectMeta(Model):
15
+ __module_type__: ClassVar[ModuleType] = ModuleType.CORE
16
+ title: str = Field(title='Title')
17
+ type: str = Field(title='Type')
18
+ default: Any | None = Field(None, title='Default')
19
+ class_schema_type: str | None = Field(None, title='Schema Type')
20
+ properties: dict[str, Optional['ClassPropertyMeta']] | None = Field(None, title='Properties') # noqa: F405
21
+ custom_code: str | None = Field(None, title='Custom Code')
22
+
23
+ @field_validator('properties')
24
+ @classmethod
25
+ def _non_empty_keys_properties(cls: type, value: Any) -> Any: # type: ignore # noqa: A003
26
+ return validate_non_empty_keys(value)
@@ -0,0 +1,15 @@
1
+ from amsdal.models.core.class_property_meta import *
2
+ from amsdal_models.classes.model import Model
3
+ from amsdal_utils.models.enums import ModuleType
4
+ from typing import Any, ClassVar
5
+
6
+ class ClassObjectMeta(Model):
7
+ __module_type__: ClassVar[ModuleType] = ...
8
+ title: str = ...
9
+ type: str = ...
10
+ default: Any | None = ...
11
+ class_schema_type: str | None = ...
12
+ properties: dict[str, ClassPropertyMeta | None] | None = ...
13
+ custom_code: str | None = ...
14
+ @classmethod
15
+ def _non_empty_keys_properties(cls, value: Any) -> Any: ...
@@ -0,0 +1,20 @@
1
+ from typing import Any
2
+ from typing import ClassVar
3
+
4
+ from amsdal_models.builder.validators.dict_validators import validate_non_empty_keys
5
+ from amsdal_models.classes.model import TypeModel
6
+ from amsdal_utils.models.enums import ModuleType
7
+ from pydantic.fields import Field
8
+ from pydantic.functional_validators import field_validator
9
+
10
+
11
+ class ClassProperty(TypeModel):
12
+ __module_type__: ClassVar[ModuleType] = ModuleType.CORE
13
+ type: str = Field(title='Type')
14
+ items: dict[str, Any | None] | None = Field(None, title='Items')
15
+ db_field: list[str] | None = Field(None, title='DB Fields')
16
+
17
+ @field_validator('items')
18
+ @classmethod
19
+ def _non_empty_keys_items(cls: type, value: Any) -> Any: # type: ignore # noqa: A003
20
+ return validate_non_empty_keys(value)
@@ -0,0 +1,11 @@
1
+ from amsdal_models.classes.model import TypeModel
2
+ from amsdal_utils.models.enums import ModuleType
3
+ from typing import Any, ClassVar
4
+
5
+ class ClassProperty(TypeModel):
6
+ __module_type__: ClassVar[ModuleType]
7
+ type: str
8
+ items: dict[str, Any | None] | None
9
+ db_field: list[str] | None
10
+ @classmethod
11
+ def _non_empty_keys_items(cls, value: Any) -> Any: ...
@@ -0,0 +1,15 @@
1
+ from typing import Any
2
+ from typing import ClassVar
3
+
4
+ from amsdal_models.classes.model import TypeModel
5
+ from amsdal_utils.models.enums import ModuleType
6
+ from pydantic.fields import Field
7
+
8
+ from amsdal.models.core.option import * # noqa: F403
9
+
10
+
11
+ class ClassPropertyMeta(TypeModel):
12
+ __module_type__: ClassVar[ModuleType] = ModuleType.CORE
13
+ title: str | None = Field(None, title='Title')
14
+ default: Any | None = Field(None, title='Default')
15
+ options: list['Option'] | None = Field(None, title='Options') # noqa: F405
@@ -0,0 +1,10 @@
1
+ from amsdal.models.core.option import *
2
+ from amsdal_models.classes.model import TypeModel
3
+ from amsdal_utils.models.enums import ModuleType
4
+ from typing import Any, ClassVar
5
+
6
+ class ClassPropertyMeta(TypeModel):
7
+ __module_type__: ClassVar[ModuleType]
8
+ title: str | None
9
+ default: Any | None
10
+ options: list['Option'] | None
@@ -0,0 +1,156 @@
1
+ import base64
2
+ from pathlib import Path
3
+ from typing import BinaryIO
4
+ from typing import ClassVar
5
+
6
+ from amsdal_models.classes.model import Model
7
+ from amsdal_utils.models.enums import ModuleType
8
+ from pydantic import field_validator
9
+ from pydantic.fields import Field
10
+
11
+
12
+ class File(Model):
13
+ __module_type__: ClassVar[ModuleType] = ModuleType.CORE
14
+ filename: str = Field(title='Filename')
15
+ data: bytes = Field(title='Data')
16
+ size: float | None = Field(None, title='Size')
17
+
18
+ def __repr__(self) -> str:
19
+ return f'File<{self.filename}>({self.size or len(self.data) or 0} bytes)'
20
+
21
+ def __str__(self) -> str:
22
+ return repr(self)
23
+
24
+ async def apre_create(self) -> None:
25
+ """
26
+ Prepares the object for creation by setting its size attribute.
27
+
28
+ This method calculates the size of the object's data and assigns it to the size attribute.
29
+ If the data is None, it defaults to an empty byte string.
30
+
31
+ Args:
32
+ None
33
+ """
34
+ self.size = len(self.data or b'')
35
+
36
+ async def apre_update(self) -> None:
37
+ """
38
+ Prepares the object for update by setting its size attribute.
39
+
40
+ This method calculates the size of the object's data and assigns it to the size attribute.
41
+ If the data is None, it defaults to an empty byte string.
42
+
43
+ Args:
44
+ None
45
+ """
46
+ self.size = len(self.data or b'')
47
+
48
+ @field_validator('data')
49
+ @classmethod
50
+ def data_base64_decode(cls, v: bytes) -> bytes:
51
+ """
52
+ Decodes a base64-encoded byte string if it is base64-encoded.
53
+
54
+ This method checks if the provided byte string is base64-encoded and decodes it if true.
55
+ If the byte string is not base64-encoded, it returns the original byte string.
56
+
57
+ Args:
58
+ cls: The class this method belongs to.
59
+ v (bytes): The byte string to be checked and potentially decoded.
60
+
61
+ Returns:
62
+ bytes: The decoded byte string if it was base64-encoded, otherwise the original byte string.
63
+ """
64
+ is_base64: bool = False
65
+ try:
66
+ is_base64 = base64.b64encode(base64.b64decode(v)) == v
67
+ except Exception:
68
+ ...
69
+ if is_base64:
70
+ return base64.b64decode(v)
71
+ return v
72
+
73
+ @classmethod
74
+ def from_file(cls, file_or_path: Path | BinaryIO) -> 'File':
75
+ """
76
+ Creates a `File` object from a file path or a binary file object.
77
+
78
+ Args:
79
+ file_or_path (Path | BinaryIO): The file path or binary file object.
80
+
81
+ Returns:
82
+ File: The created `File` object.
83
+
84
+ Raises:
85
+ ValueError: If the provided path is a directory.
86
+ """
87
+ if isinstance(file_or_path, Path):
88
+ if file_or_path.is_dir():
89
+ msg = f'{file_or_path} is a directory'
90
+ raise ValueError(msg)
91
+ data = file_or_path.read_bytes()
92
+ filename = file_or_path.name
93
+ else:
94
+ file_or_path.seek(0)
95
+ data = file_or_path.read()
96
+ filename = Path(file_or_path.name).name
97
+ return cls(data=data, filename=filename) # type: ignore[call-arg]
98
+
99
+ @property
100
+ def mimetype(self) -> str | None:
101
+ """
102
+ Returns the MIME type of the file based on its filename.
103
+
104
+ This method uses the `mimetypes` module to guess the MIME type of the file.
105
+
106
+ Returns:
107
+ str | None: The guessed MIME type of the file, or None if it cannot be determined.
108
+ """
109
+ import mimetypes
110
+
111
+ return mimetypes.guess_type(self.filename)[0]
112
+
113
+ def pre_create(self) -> None:
114
+ """
115
+ Prepares the object for creation by setting its size attribute.
116
+
117
+ This method calculates the size of the object's data and assigns it to the size attribute.
118
+ If the data is None, it defaults to an empty byte string.
119
+
120
+ Args:
121
+ None
122
+ """
123
+ self.size = len(self.data or b'')
124
+
125
+ def pre_update(self) -> None:
126
+ """
127
+ Prepares the object for update by setting its size attribute.
128
+
129
+ This method calculates the size of the object's data and assigns it to the size attribute.
130
+ If the data is None, it defaults to an empty byte string.
131
+
132
+ Args:
133
+ None
134
+ """
135
+ self.size = len(self.data or b'')
136
+
137
+ def to_file(self, file_or_path: Path | BinaryIO) -> None:
138
+ """
139
+ Writes the object's data to a file path or a binary file object.
140
+
141
+ Args:
142
+ file_or_path (Path | BinaryIO): The file path or binary file object where the data will be written.
143
+
144
+ Returns:
145
+ None
146
+
147
+ Raises:
148
+ ValueError: If the provided path is a directory.
149
+ """
150
+ if isinstance(file_or_path, Path):
151
+ if file_or_path.is_dir():
152
+ file_or_path = file_or_path / self.name
153
+ file_or_path.write_bytes(self.data) # type: ignore[union-attr]
154
+ else:
155
+ file_or_path.write(self.data)
156
+ file_or_path.seek(0)