documente_shared 0.1.86__py3-none-any.whl → 0.1.87__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.
Potentially problematic release.
This version of documente_shared might be problematic. Click here for more details.
- documente_shared/domain/entities/processing_case_filters.py +1 -0
- documente_shared/domain/entities/processing_case_item_filters.py +1 -0
- documente_shared/domain/entities/scaling.py +25 -0
- documente_shared/domain/interfaces/__init__.py +0 -0
- documente_shared/domain/interfaces/scaling.py +10 -0
- documente_shared/domain/repositories/processing_case.py +1 -1
- documente_shared/domain/repositories/processing_case_item.py +0 -1
- documente_shared/infrastructure/repositories/dynamo_processing_case.py +1 -1
- documente_shared/infrastructure/repositories/dynamo_processing_case_item.py +1 -2
- documente_shared/infrastructure/repositories/http_processing_case.py +3 -2
- documente_shared/infrastructure/repositories/http_processing_case_item.py +12 -0
- documente_shared/infrastructure/services/__init__.py +0 -0
- documente_shared/infrastructure/services/http_scaling.py +24 -0
- {documente_shared-0.1.86.dist-info → documente_shared-0.1.87.dist-info}/METADATA +2 -1
- {documente_shared-0.1.86.dist-info → documente_shared-0.1.87.dist-info}/RECORD +16 -11
- {documente_shared-0.1.86.dist-info → documente_shared-0.1.87.dist-info}/WHEEL +0 -0
|
@@ -17,6 +17,7 @@ class ProcessingCaseFilters(object):
|
|
|
17
17
|
statuses: List[ProcessingStatus] = None
|
|
18
18
|
case_types: List[ProcessingCaseType] = None
|
|
19
19
|
include_archived: bool = False
|
|
20
|
+
tenant_slug: Optional[str] = None
|
|
20
21
|
|
|
21
22
|
def __post_init__(self):
|
|
22
23
|
self.case_ids = self.case_ids or []
|
|
@@ -20,6 +20,7 @@ class ProcessingCaseItemFilters(object):
|
|
|
20
20
|
statuses: List[ProcessingStatus] = None
|
|
21
21
|
document_types: List[ProcessingDocumentType] = None
|
|
22
22
|
include_archived: bool = False
|
|
23
|
+
tenant_slug: Optional[str] = None
|
|
23
24
|
|
|
24
25
|
def __post_init__(self):
|
|
25
26
|
self.statuses = self.statuses or []
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
from dataclasses import dataclass
|
|
2
|
+
from typing import Optional
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
@dataclass
|
|
6
|
+
class ScalingRequirements(object):
|
|
7
|
+
documents: Optional[int] = 0
|
|
8
|
+
processing_cases: Optional[int] = 0
|
|
9
|
+
processing_case_items: Optional[int] = 0
|
|
10
|
+
|
|
11
|
+
@property
|
|
12
|
+
def to_dict(self):
|
|
13
|
+
return {
|
|
14
|
+
"documents": self.documents,
|
|
15
|
+
"processing_cases": self.processing_cases,
|
|
16
|
+
"processing_case_items": self.processing_case_items,
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
@classmethod
|
|
20
|
+
def from_dict(cls, data: dict) -> "ScalingRequirements":
|
|
21
|
+
return cls(
|
|
22
|
+
documents=data.get("documents", 0),
|
|
23
|
+
processing_cases=data.get("processing_cases", 0),
|
|
24
|
+
processing_case_items=data.get("processing_case_items", 0),
|
|
25
|
+
)
|
|
File without changes
|
|
@@ -20,5 +20,5 @@ class ProcessingCaseRepository(ABC):
|
|
|
20
20
|
raise NotImplementedError
|
|
21
21
|
|
|
22
22
|
@abstractmethod
|
|
23
|
-
def filter(self,
|
|
23
|
+
def filter(self, filters: ProcessingCaseFilters) -> List[ProcessingCase]:
|
|
24
24
|
raise NotImplementedError
|
|
@@ -26,7 +26,7 @@ class DynamoProcessingCaseRepository(
|
|
|
26
26
|
def remove(self, instance: ProcessingCase):
|
|
27
27
|
self.delete(key={'uuid': instance.uuid})
|
|
28
28
|
|
|
29
|
-
def filter(self,
|
|
29
|
+
def filter(self, filters: ProcessingCaseFilters) -> List[ProcessingCase]:
|
|
30
30
|
items = []
|
|
31
31
|
|
|
32
32
|
for status in filters.statuses:
|
|
@@ -34,7 +34,6 @@ class DynamoProcessingCaseItemRepository(
|
|
|
34
34
|
|
|
35
35
|
def filter(
|
|
36
36
|
self,
|
|
37
|
-
tenant_slug: str,
|
|
38
37
|
filters: ProcessingCaseItemFilters,
|
|
39
38
|
) -> List[ProcessingCaseItem]:
|
|
40
39
|
items = []
|
|
@@ -50,4 +49,4 @@ class DynamoProcessingCaseItemRepository(
|
|
|
50
49
|
return [
|
|
51
50
|
ProcessingCaseItem.from_dict(item)
|
|
52
51
|
for item in items
|
|
53
|
-
]
|
|
52
|
+
]
|
|
@@ -34,11 +34,11 @@ class HttpProcessingCaseRepository(
|
|
|
34
34
|
def remove(self, instance: ProcessingCase):
|
|
35
35
|
self.session.delete(f"{self.api_url}/v1/processing-cases/{instance.uuid}/")
|
|
36
36
|
|
|
37
|
-
def filter(self,
|
|
37
|
+
def filter(self, filters: ProcessingCaseFilters) -> List[ProcessingCase]:
|
|
38
38
|
response = self.session.get(
|
|
39
39
|
url=f"{self.api_url}/v1/processing-cases/",
|
|
40
40
|
headers={
|
|
41
|
-
"X-Tenant": tenant_slug,
|
|
41
|
+
"X-Tenant": filters.tenant_slug,
|
|
42
42
|
}
|
|
43
43
|
)
|
|
44
44
|
if response.status_code == 200:
|
|
@@ -49,6 +49,7 @@ class HttpProcessingCaseRepository(
|
|
|
49
49
|
]
|
|
50
50
|
return []
|
|
51
51
|
|
|
52
|
+
|
|
52
53
|
@classmethod
|
|
53
54
|
def _build_processing_case(cls, response: Response) -> ProcessingCase:
|
|
54
55
|
response_json = response.json()
|
|
@@ -40,6 +40,18 @@ class HttpProcessingCaseItemRepository(
|
|
|
40
40
|
self.session.delete(f"{self.api_url}/v1/processing-case-items/{instance.uuid}/")
|
|
41
41
|
|
|
42
42
|
def filter(
|
|
43
|
+
self,
|
|
44
|
+
filters: ProcessingCaseItemFilters,
|
|
45
|
+
) -> List[ProcessingCaseItem]:
|
|
46
|
+
response = self.session.get(f"{self.api_url}/v1/processing-case-items/")
|
|
47
|
+
if response.status_code == 200:
|
|
48
|
+
raw_response = response.json()
|
|
49
|
+
return [
|
|
50
|
+
ProcessingCaseItem.from_dict(camel_to_snake(item_data))
|
|
51
|
+
for item_data in raw_response.get('data', [])
|
|
52
|
+
]
|
|
53
|
+
return []
|
|
54
|
+
def filter_with_tenant(
|
|
43
55
|
self,
|
|
44
56
|
tenant_slug: str,
|
|
45
57
|
filters: ProcessingCaseItemFilters,
|
|
File without changes
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
from dataclasses import dataclass
|
|
2
|
+
|
|
3
|
+
from loguru import logger
|
|
4
|
+
|
|
5
|
+
from documente_shared.application.payloads import camel_to_snake
|
|
6
|
+
from documente_shared.domain.entities.scaling import ScalingRequirements
|
|
7
|
+
from documente_shared.domain.interfaces.scaling import ScalingService
|
|
8
|
+
from documente_shared.infrastructure.documente_client import DocumenteClientMixin
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
@dataclass
|
|
12
|
+
class HttpScalingService(
|
|
13
|
+
DocumenteClientMixin,
|
|
14
|
+
ScalingService,
|
|
15
|
+
):
|
|
16
|
+
def get_scaling_requirements(self) -> ScalingRequirements:
|
|
17
|
+
response = self.session.get(f"{self.api_url}/v1/scaling-requirements/")
|
|
18
|
+
if response.status_code == 200:
|
|
19
|
+
return ScalingRequirements.from_dict(
|
|
20
|
+
data=camel_to_snake(response.json())
|
|
21
|
+
)
|
|
22
|
+
|
|
23
|
+
logger.warning(f'Error getting scaling requirements: {response.text}')
|
|
24
|
+
return ScalingRequirements()
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: documente_shared
|
|
3
|
-
Version: 0.1.
|
|
3
|
+
Version: 0.1.87
|
|
4
4
|
Summary: Shared utilities for Documente AI projects
|
|
5
5
|
License: MIT
|
|
6
6
|
Author: Tech
|
|
@@ -13,6 +13,7 @@ Classifier: Programming Language :: Python :: 3.11
|
|
|
13
13
|
Classifier: Programming Language :: Python :: 3.12
|
|
14
14
|
Requires-Dist: boto3 (>=1.37.19,<2.0.0)
|
|
15
15
|
Requires-Dist: botocore (>=1.37.19,<2.0.0)
|
|
16
|
+
Requires-Dist: loguru (>=0.7.3,<0.8.0)
|
|
16
17
|
Requires-Dist: pytz (>=2025.2,<2026.0)
|
|
17
18
|
Requires-Dist: requests (>=2.32.3,<3.0.0)
|
|
18
19
|
Requires-Dist: sentry-sdk (>=2.19.2,<3.0.0)
|
|
@@ -16,33 +16,38 @@ documente_shared/domain/entities/document.py,sha256=AthTUyA-QZE3WAT7lMoKVr_Z8mO_
|
|
|
16
16
|
documente_shared/domain/entities/document_metadata.py,sha256=ygyFIC5qwxlm8DUM5kvVFny9zJfPQS8vNLM2br5XsQ8,2353
|
|
17
17
|
documente_shared/domain/entities/in_memory_result.py,sha256=0sLNUrovKFQx4M-E9e4DrAiVgch2i4AKA-9BQBRaeI8,1482
|
|
18
18
|
documente_shared/domain/entities/processing_case.py,sha256=_UTMCSQjTSttNWa-NC7eWJITkNm6NZuGGT9gNm9D1mA,4970
|
|
19
|
-
documente_shared/domain/entities/processing_case_filters.py,sha256=
|
|
19
|
+
documente_shared/domain/entities/processing_case_filters.py,sha256=harKyu7QEuL1bI_Z8_UxkVCMo5r9vHeNHyi_Ja07vjs,1953
|
|
20
20
|
documente_shared/domain/entities/processing_case_item.py,sha256=U_g99AJdlRRJpJ0NPfmXzlr2x04l5hc53oNLxx_Q7XQ,9734
|
|
21
|
-
documente_shared/domain/entities/processing_case_item_filters.py,sha256
|
|
21
|
+
documente_shared/domain/entities/processing_case_item_filters.py,sha256=R_AvDCB496Lww1qn2OwtltqULKE3IpcJB0ejnmRkg7Q,2009
|
|
22
22
|
documente_shared/domain/entities/processing_event.py,sha256=AMkW4dJjW6ss-uvDeWzVMBIJtax8JNWy-zPo1R-TiWY,1963
|
|
23
|
+
documente_shared/domain/entities/scaling.py,sha256=Me1z3X-5NjzPMX-TBQ4xHwE_44tIJegi1QSCHQRNtx4,745
|
|
23
24
|
documente_shared/domain/enums/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
24
25
|
documente_shared/domain/enums/common.py,sha256=wJWYhh98sdCGL_1WodhYLpoT_IYTzkTDOexclpaIM-0,2827
|
|
25
26
|
documente_shared/domain/enums/document.py,sha256=QwvckW-VJBSujllIVloKlZUh1pI5UnX4oueYbV5CYGw,3205
|
|
26
27
|
documente_shared/domain/enums/processing_case.py,sha256=LhFhcoWlockxcpplsVdC6M2kpXn7sOdzQySf24wFhx8,1572
|
|
28
|
+
documente_shared/domain/interfaces/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
29
|
+
documente_shared/domain/interfaces/scaling.py,sha256=0Mefc_GVNdyRtAdkxlnvQuXrmM4Yx7VOJQCfVZOgISQ,257
|
|
27
30
|
documente_shared/domain/repositories/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
28
31
|
documente_shared/domain/repositories/document.py,sha256=vJzr6c92gqBzyhaEdjrvnoneKRrWmJ0AsvocPnhxiLU,767
|
|
29
|
-
documente_shared/domain/repositories/processing_case.py,sha256=
|
|
30
|
-
documente_shared/domain/repositories/processing_case_item.py,sha256=
|
|
32
|
+
documente_shared/domain/repositories/processing_case.py,sha256=QcY0LumRokRLmL3IWkOZTgN-LQ-Kku5_v7DWujO1Dfw,778
|
|
33
|
+
documente_shared/domain/repositories/processing_case_item.py,sha256=uBgJN2fJnZDcKUk018P_Fv25dQRZD5FBxFxsCQNaGAQ,948
|
|
31
34
|
documente_shared/infrastructure/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
32
35
|
documente_shared/infrastructure/documente_client.py,sha256=paO66zNelDyA6D6iqTXXFVQ9ERRZoJCGWR3T3hySsaM,503
|
|
33
36
|
documente_shared/infrastructure/dynamo_table.py,sha256=TMQbcuty7wjDMbuhI8PbT0IGXelgELsNTtqTEQeZ824,2112
|
|
34
37
|
documente_shared/infrastructure/lambdas.py,sha256=sGgkw7Mhvuq2TpbW_RNdf5JvQnuzxWYH6gPOVtQ4DtE,357
|
|
35
38
|
documente_shared/infrastructure/repositories/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
36
39
|
documente_shared/infrastructure/repositories/dynamo_document.py,sha256=_Yp4gtA-n-hJ2w2wAM5BMCs2Mf46Q2Kq3eHqlxudkL4,1443
|
|
37
|
-
documente_shared/infrastructure/repositories/dynamo_processing_case.py,sha256=
|
|
38
|
-
documente_shared/infrastructure/repositories/dynamo_processing_case_item.py,sha256=
|
|
40
|
+
documente_shared/infrastructure/repositories/dynamo_processing_case.py,sha256=jkTVHThKHshLI53OV7ivK-WchFoAZTnaXlgh_1OX52k,1446
|
|
41
|
+
documente_shared/infrastructure/repositories/dynamo_processing_case_item.py,sha256=B2ElsASpXNRkwwjdCqXyvDU-LBrLNdwPfHLMvvG9c-Y,1729
|
|
39
42
|
documente_shared/infrastructure/repositories/http_document_processing.py,sha256=7n4lHgpN17CCr4_Dz9WRbsXeb4FDMJZNDUshFipA1B8,2179
|
|
40
|
-
documente_shared/infrastructure/repositories/http_processing_case.py,sha256=
|
|
41
|
-
documente_shared/infrastructure/repositories/http_processing_case_item.py,sha256=
|
|
43
|
+
documente_shared/infrastructure/repositories/http_processing_case.py,sha256=n1NXJtROTfet2QCKSNnQtLmcNgkJDo6q0Hq48FSpwEU,2249
|
|
44
|
+
documente_shared/infrastructure/repositories/http_processing_case_item.py,sha256=cCi7uo1aHPhroxRRlFOhIUgGkY_S2dvWl1DAVr_maxw,2966
|
|
42
45
|
documente_shared/infrastructure/s3_bucket.py,sha256=vT_yN42RFQXubtUn8ln-j13Os_-25UGClVtXg5Bkv6I,1932
|
|
46
|
+
documente_shared/infrastructure/services/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
47
|
+
documente_shared/infrastructure/services/http_scaling.py,sha256=SK0vReNGXzfN2yKNiYq9u1fvDECU5dHynq5507i7fgI,856
|
|
43
48
|
documente_shared/infrastructure/sqs_queue.py,sha256=KZWeHZ9zmXmrxoNpOQX7GEdDhZ1knbPXgwSwFwJblGg,1504
|
|
44
49
|
documente_shared/presentation/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
45
50
|
documente_shared/presentation/presenters.py,sha256=GGAEwefmjCIVepsUA2oZOVLxXbhhiISPM0Jgt6dT6O0,423
|
|
46
|
-
documente_shared-0.1.
|
|
47
|
-
documente_shared-0.1.
|
|
48
|
-
documente_shared-0.1.
|
|
51
|
+
documente_shared-0.1.87.dist-info/METADATA,sha256=zTsM418cXINfRJx1HAF_JUXqd7Pr8mYEkcuXPt8Ah5A,920
|
|
52
|
+
documente_shared-0.1.87.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
|
|
53
|
+
documente_shared-0.1.87.dist-info/RECORD,,
|
|
File without changes
|