architectonics 0.0.35__tar.gz → 0.0.37__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.
- {architectonics-0.0.35 → architectonics-0.0.37}/PKG-INFO +1 -1
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/services/base_service.py +5 -5
- architectonics-0.0.37/architectonics/core/services/user_auth_service.py +52 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/repositories/base_repository.py +2 -2
- {architectonics-0.0.35 → architectonics-0.0.37}/pyproject.toml +1 -1
- {architectonics-0.0.35 → architectonics-0.0.37}/setup.py +1 -1
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/common/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/common/utils/utils.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/config/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/config/application_settings.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/factory/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/factory/factory.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/models/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/models/base_model.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/models/deleted_models.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/result/error_message.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/result/service_result.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/schemas/base_schemas.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/services/base_schemas.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/validation/base_model_validation_errors.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/config/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/config/database.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/config/database_settings.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/entities/base_entity.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/repositories/__init__.py +0 -0
- {architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/repositories/base_exceptions.py +0 -0
{architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/services/base_service.py
RENAMED
|
@@ -68,11 +68,11 @@ class BaseService:
|
|
|
68
68
|
model_id: str,
|
|
69
69
|
) -> ServiceResult[BaseModel, BaseModelValidationErrors]:
|
|
70
70
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
71
|
+
model = await self._repository.get_model_by_id(
|
|
72
|
+
model_id=model_id,
|
|
73
|
+
)
|
|
74
|
+
|
|
75
|
+
if model is None:
|
|
76
76
|
return ServiceResult[BaseModel, BaseModelValidationErrors].failure(
|
|
77
77
|
error_message="object_not_found",
|
|
78
78
|
)
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
from uuid import UUID
|
|
2
|
+
|
|
3
|
+
from fastapi import Depends, Header, HTTPException
|
|
4
|
+
from starlette.status import HTTP_400_BAD_REQUEST
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
def get_user_id(
|
|
8
|
+
x_user_id: str = Header(
|
|
9
|
+
alias="X-User-Id",
|
|
10
|
+
description="Идентификатор пользователя",
|
|
11
|
+
),
|
|
12
|
+
) -> str:
|
|
13
|
+
if not x_user_id:
|
|
14
|
+
raise HTTPException(
|
|
15
|
+
status_code=HTTP_400_BAD_REQUEST,
|
|
16
|
+
detail="X-User-Id header is required",
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
try:
|
|
20
|
+
_ = UUID(x_user_id, version=4) # version=4 для проверки UUID v4
|
|
21
|
+
except ValueError:
|
|
22
|
+
raise HTTPException(
|
|
23
|
+
status_code=HTTP_400_BAD_REQUEST,
|
|
24
|
+
detail="not_valid_uuid",
|
|
25
|
+
)
|
|
26
|
+
|
|
27
|
+
return x_user_id
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
def get_user_roles(
|
|
31
|
+
x_user_roles: str = Header(
|
|
32
|
+
alias="X-User-Roles",
|
|
33
|
+
description="Роли пользователя",
|
|
34
|
+
),
|
|
35
|
+
) -> str:
|
|
36
|
+
if not x_user_roles:
|
|
37
|
+
raise HTTPException(
|
|
38
|
+
status_code=HTTP_400_BAD_REQUEST,
|
|
39
|
+
detail="X-User-Roles header is required",
|
|
40
|
+
)
|
|
41
|
+
|
|
42
|
+
return x_user_roles.split(",")
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
class UserAuthService:
|
|
46
|
+
def __init__(
|
|
47
|
+
self,
|
|
48
|
+
user_id: str = Depends(get_user_id),
|
|
49
|
+
user_roles: list[str] = Depends(get_user_roles),
|
|
50
|
+
):
|
|
51
|
+
self.user_id = user_id
|
|
52
|
+
self.user_roles = user_roles
|
|
@@ -49,7 +49,7 @@ class BaseRepository(ABC):
|
|
|
49
49
|
async def get_model_by_id(
|
|
50
50
|
self,
|
|
51
51
|
model_id: str,
|
|
52
|
-
) -> BaseModel:
|
|
52
|
+
) -> BaseModel | None:
|
|
53
53
|
|
|
54
54
|
statement = select(
|
|
55
55
|
self._entity,
|
|
@@ -66,7 +66,7 @@ class BaseRepository(ABC):
|
|
|
66
66
|
entity = result.scalars().first()
|
|
67
67
|
|
|
68
68
|
if entity is None:
|
|
69
|
-
|
|
69
|
+
return None
|
|
70
70
|
|
|
71
71
|
return entity.to_model()
|
|
72
72
|
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/config/application_settings.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/models/deleted_models.py
RENAMED
|
File without changes
|
|
File without changes
|
{architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/result/service_result.py
RENAMED
|
File without changes
|
|
File without changes
|
{architectonics-0.0.35 → architectonics-0.0.37}/architectonics/core/services/base_schemas.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/config/__init__.py
RENAMED
|
File without changes
|
{architectonics-0.0.35 → architectonics-0.0.37}/architectonics/infrastructure/config/database.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|