cuenca-validations 2.1.37__tar.gz → 2.1.38__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.
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/PKG-INFO +1 -1
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/requests.py +16 -2
- cuenca_validations-2.1.38/cuenca_validations/version.py +1 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations.egg-info/PKG-INFO +1 -1
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/tests/test_types.py +9 -21
- cuenca_validations-2.1.37/cuenca_validations/version.py +0 -1
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/LICENSE +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/README.md +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/__init__.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/card_bins.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/errors.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/py.typed +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/__init__.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/card.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/enums.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/files.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/general.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/helpers.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/identities.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/morals.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/queries.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/typing.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/validators.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations.egg-info/SOURCES.txt +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations.egg-info/dependency_links.txt +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations.egg-info/requires.txt +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations.egg-info/top_level.txt +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/setup.cfg +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/setup.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/tests/__init__.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/tests/test_card.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/tests/test_errors.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/tests/test_helpers.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/tests/test_requests.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/tests/test_statement.py +0 -0
- {cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/tests/test_validators.py +0 -0
{cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/requests.py
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import datetime as dt
|
|
2
2
|
from typing import Annotated, Any, Optional, Union
|
|
3
3
|
|
|
4
|
-
from clabe import Clabe
|
|
4
|
+
from clabe import BANK_NAMES, Clabe
|
|
5
5
|
from pydantic import (
|
|
6
6
|
BaseModel,
|
|
7
7
|
ConfigDict,
|
|
@@ -326,10 +326,24 @@ class WalletTransactionRequest(BaseRequest):
|
|
|
326
326
|
|
|
327
327
|
class FraudFundsTransferRequest(BaseRequest):
|
|
328
328
|
user_id: NonEmptyStr
|
|
329
|
-
clabe: Clabe
|
|
329
|
+
clabe: Optional[Clabe] = None
|
|
330
|
+
bank_code: Optional[str] = None
|
|
330
331
|
amount: Optional[StrictPositiveInt] = None
|
|
331
332
|
concepto: Optional[NonEmptyStr] = None
|
|
332
333
|
|
|
334
|
+
@field_validator('bank_code')
|
|
335
|
+
@classmethod
|
|
336
|
+
def validate_bank_code(cls, bank_code: Optional[str]) -> Optional[str]:
|
|
337
|
+
if bank_code is not None and bank_code not in BANK_NAMES:
|
|
338
|
+
raise ValueError('Not a valid bank code')
|
|
339
|
+
return bank_code
|
|
340
|
+
|
|
341
|
+
@model_validator(mode='after')
|
|
342
|
+
def validate_destination(self) -> 'FraudFundsTransferRequest':
|
|
343
|
+
if self.clabe is None and self.bank_code is None:
|
|
344
|
+
raise ValueError('clabe or bank_code required')
|
|
345
|
+
return self
|
|
346
|
+
|
|
333
347
|
|
|
334
348
|
class FraudValidationRequest(BaseModel):
|
|
335
349
|
amount: StrictPositiveInt
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
__version__ = '2.1.38'
|
|
@@ -676,30 +676,18 @@ def test_bank_account_validation_clabe_request():
|
|
|
676
676
|
|
|
677
677
|
|
|
678
678
|
def test_fraud_funds_transfer_request():
|
|
679
|
-
|
|
679
|
+
assert FraudFundsTransferRequest(
|
|
680
680
|
user_id='US123',
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
concepto=' Devolución fraude ',
|
|
684
|
-
)
|
|
685
|
-
|
|
686
|
-
assert request.concepto == 'Devolución fraude'
|
|
687
|
-
assert request.model_dump() == {
|
|
688
|
-
'user_id': 'US123',
|
|
689
|
-
'clabe': '646180157098510917',
|
|
690
|
-
'amount': 10000,
|
|
691
|
-
'concepto': 'Devolución fraude',
|
|
692
|
-
}
|
|
681
|
+
bank_code='40012',
|
|
682
|
+
).model_dump() == {'user_id': 'US123', 'bank_code': '40012'}
|
|
693
683
|
|
|
694
|
-
|
|
695
|
-
user_id='US123'
|
|
696
|
-
|
|
697
|
-
)
|
|
684
|
+
with pytest.raises(ValidationError) as exc:
|
|
685
|
+
FraudFundsTransferRequest(user_id='US123')
|
|
686
|
+
assert 'clabe or bank_code required' in str(exc.value)
|
|
698
687
|
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
}
|
|
688
|
+
with pytest.raises(ValidationError) as exc:
|
|
689
|
+
FraudFundsTransferRequest(user_id='US123', bank_code='99999')
|
|
690
|
+
assert 'Not a valid bank code' in str(exc.value)
|
|
703
691
|
|
|
704
692
|
|
|
705
693
|
@pytest.mark.parametrize(
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
__version__ = '2.1.37'
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations/types/identities.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations.egg-info/SOURCES.txt
RENAMED
|
File without changes
|
|
File without changes
|
{cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations.egg-info/requires.txt
RENAMED
|
File without changes
|
{cuenca_validations-2.1.37 → cuenca_validations-2.1.38}/cuenca_validations.egg-info/top_level.txt
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|