architectonics 0.0.28__tar.gz → 0.0.30__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 (27) hide show
  1. {architectonics-0.0.28 → architectonics-0.0.30}/PKG-INFO +1 -1
  2. architectonics-0.0.30/architectonics/core/models/base_model.py +9 -0
  3. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/services/base_service.py +17 -7
  4. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/infrastructure/entities/base_entity.py +4 -0
  5. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/infrastructure/repositories/base_repository.py +6 -4
  6. {architectonics-0.0.28 → architectonics-0.0.30}/pyproject.toml +1 -1
  7. {architectonics-0.0.28 → architectonics-0.0.30}/setup.py +1 -1
  8. architectonics-0.0.28/architectonics/core/models/base_model.py +0 -9
  9. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/__init__.py +0 -0
  10. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/common/__init__.py +0 -0
  11. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/common/utils/utils.py +0 -0
  12. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/__init__.py +0 -0
  13. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/config/__init__.py +0 -0
  14. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/config/application_settings.py +0 -0
  15. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/factory/__init__.py +0 -0
  16. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/factory/factory.py +0 -0
  17. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/models/__init__.py +0 -0
  18. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/result/error_message.py +0 -0
  19. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/result/service_result.py +0 -0
  20. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/services/base_schemas.py +0 -0
  21. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/core/validation/base_model_validation_errors.py +0 -0
  22. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/infrastructure/__init__.py +0 -0
  23. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/infrastructure/config/__init__.py +0 -0
  24. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/infrastructure/config/database.py +0 -0
  25. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/infrastructure/config/database_settings.py +0 -0
  26. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/infrastructure/repositories/__init__.py +0 -0
  27. {architectonics-0.0.28 → architectonics-0.0.30}/architectonics/infrastructure/repositories/base_exceptions.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: architectonics
3
- Version: 0.0.28
3
+ Version: 0.0.30
4
4
  Summary:
5
5
  Author: Your Name
6
6
  Author-email: you@example.com
@@ -0,0 +1,9 @@
1
+ from dataclasses import dataclass, field
2
+ from datetime import datetime
3
+ import uuid
4
+
5
+ @dataclass
6
+ class BaseModel:
7
+ id: str = field(default_factory=lambda: str(uuid.uuid4()))
8
+ created_at: datetime = field(default_factory=datetime.utcnow)
9
+ updated_at: datetime = field(default_factory=datetime.utcnow)
@@ -31,7 +31,7 @@ class BaseService:
31
31
 
32
32
  return ServiceResult[list[BaseModel], BaseModelValidationErrors].success(models)
33
33
 
34
- """async def validate(self, model: BaseModel) -> BaseModelValidationErrors:
34
+ async def validate(self, model: BaseModel) -> BaseModelValidationErrors:
35
35
 
36
36
  errors = BaseModelValidationErrors()
37
37
 
@@ -42,19 +42,29 @@ class BaseService:
42
42
  model: BaseModel,
43
43
  ) -> ServiceResult[BaseModel, BaseModelValidationErrors]:
44
44
 
45
- model_errors = await self.validate(model)
45
+ validation_errors = await self.validate(model)
46
46
 
47
- if model_errors.has_errors():
48
- return None, model_errors, HTTP_422_UNPROCESSABLE_CONTENT
47
+ if validation_errors.has_errors():
48
+ return ServiceResult[BaseModel, BaseModelValidationErrors].validation_failure(
49
+ validation_errors=validation_errors,
50
+ )
49
51
 
50
52
  try:
51
53
  model = await self._repository.create_model(
52
- values=values,
54
+ model=model,
53
55
  )
54
56
  except ObjectAlreadyExistsException:
55
- return None, "object_already_exist", HTTP_409_CONFLICT
57
+ return ServiceResult[BaseModel, BaseModelValidationErrors].failure(
58
+ error_message="object_already_exists",
59
+ )
56
60
 
57
- return model, None, HTTP_200_OK
61
+ return ServiceResult[BaseModel, BaseModelValidationErrors].success(
62
+ value=model,
63
+ )
64
+
65
+ """
66
+
67
+
58
68
 
59
69
  async def get_model(
60
70
  self,
@@ -32,3 +32,7 @@ class BaseEntity:
32
32
 
33
33
  def to_model(self) -> BaseModel:
34
34
  raise NotImplementedError()
35
+
36
+ @classmethod
37
+ def from_model(model: BaseModel) -> BaseEntity:
38
+ raise NotImplementedError()
@@ -2,8 +2,8 @@ from abc import ABC
2
2
  from typing import Callable
3
3
 
4
4
  from asyncpg.exceptions import ForeignKeyViolationError
5
- from infrastructure.entities.base_entity import BaseEntity
6
- from infrastructure.repositories.base_exceptions import (
5
+ from architectonics.infrastructure.entities.base_entity import BaseEntity
6
+ from architectonics.infrastructure.repositories.base_exceptions import (
7
7
  IntegrityErrorException,
8
8
  ObjectAlreadyExistsException,
9
9
  ObjectNotFoundException,
@@ -29,10 +29,12 @@ class BaseRepository(ABC):
29
29
 
30
30
  async def create_model(
31
31
  self,
32
- values: dict[str, any],
32
+ model: BaseModel,
33
33
  ) -> BaseModel:
34
34
 
35
- entity = self._entity(**values)
35
+ entity: BaseEntity = self._entity.from_model(
36
+ model=model,
37
+ )
36
38
 
37
39
  async with self.get_session() as session:
38
40
  session.add(entity)
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "architectonics"
3
- version = "0.0.28"
3
+ version = "0.0.30"
4
4
  description = ""
5
5
  authors = ["Your Name <you@example.com>"]
6
6
 
@@ -32,7 +32,7 @@ install_requires = \
32
32
 
33
33
  setup_kwargs = {
34
34
  'name': 'architectonics',
35
- 'version': '0.0.28',
35
+ 'version': '0.0.30',
36
36
  'description': '',
37
37
  'long_description': None,
38
38
  'author': 'Your Name',
@@ -1,9 +0,0 @@
1
- from dataclasses import dataclass
2
- from datetime import datetime
3
-
4
-
5
- @dataclass
6
- class BaseModel:
7
- id: str
8
- created_at: datetime
9
- updated_at: datetime