Skip to content

Commit

Permalink
Merge pull request #91 from sicpa-dlab/fix/msg-validation-error-enhan…
Browse files Browse the repository at this point in the history
…cement

Message validation enhancement
  • Loading branch information
yvgny committed Mar 9, 2023
2 parents ac4696c + 6da1d92 commit 47d6428
Show file tree
Hide file tree
Showing 7 changed files with 458 additions and 494 deletions.
27 changes: 25 additions & 2 deletions didcomm/core/validators.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,23 +20,46 @@ def _f(instance, attribute, value):
return _f


def validator__optional(validator: Callable) -> Callable:
return _attr_validator_wrapper(attr.validators.optional(validator))


# TODO TEST
def validator__instance_of(classinfo) -> Callable:
return _attr_validator_wrapper(attr.validators.instance_of(classinfo))


def validator__and_(*validators: Callable):
return _attr_validator_wrapper(attr.validators.and_(*validators))


# TODO TEST
def validator__in_(options) -> Callable:
return _attr_validator_wrapper(attr.validators.in_(options))


def validator__not_in_(options) -> Callable:
return _attr_validator_wrapper(attr.validators.not_(attr.validators.in_(options)))


# TODO TEST
def validator__deep_iterable(member_validator: Callable, iterable_validator=None):
return _attr_validator_wrapper(
attr.validators.deep_iterable(member_validator, iterable_validator)
)


# TODO TEST
def validator__deep_mapping(
key_validator: Callable,
value_validator: Callable,
mapping_validator: Callable = None,
):
return _attr_validator_wrapper(
attr.validators.deep_mapping(key_validator, value_validator, mapping_validator)
)


# TODO TEST
def validator__didcomm_protocol_mturi(
p_name: str, p_version_specifier: SpecifierSet, p_msg_t: str
Expand Down Expand Up @@ -83,8 +106,8 @@ def _f(instance, attribute, value):


# TODO TEST
def validator__did(instance, attribute, value) -> None:
validator__check_f(is_did, "is not a did")(instance, attribute, value)
def validator__did() -> Callable:
return validator__check_f(is_did, "is not a did")


# TODO TEST
Expand Down
Loading

0 comments on commit 47d6428

Please sign in to comment.