Skip to content

aea.configurations.validation

Implementation of the configuration validation.

make_jsonschema_base_uri

def make_jsonschema_base_uri(base_uri_path: Path) -> str

Make the JSONSchema base URI, cross-platform.

Arguments:

  • base_uri_path: the path to the base directory.

Returns:

the string in URI form.

ExtraPropertiesError Objects

class ExtraPropertiesError(ValueError)

Extra properties exception.

__str__

def __str__() -> str

Get string representation of the object.

__repr__

def __repr__() -> str

Get string representation of the object.

CustomTypeChecker Objects

class CustomTypeChecker(TypeChecker)

Custom type checker to handle env variables.

is_type

def is_type(instance, type) -> bool

Check is instance of type.

own_additional_properties

def own_additional_properties(validator, aP, instance, schema) -> Iterator

Additional properties validator.

ConfigValidator Objects

class ConfigValidator()

Configuration validator implementation.

__init__

def __init__(schema_filename: str, env_vars_friendly: bool = False) -> None

Initialize the parser for configuration files.

Arguments:

  • schema_filename: the path to the JSON-schema file in 'aea/configurations/schemas'.
  • env_vars_friendly: whether or not it is env var friendly.

split_component_id_and_config

@staticmethod
def split_component_id_and_config(
        component_index: int,
        component_configuration_json: Dict) -> ComponentId

Split component id and configuration.

Arguments:

  • component_index: the position of the component configuration in the agent config file..
  • component_configuration_json: the JSON object to process.

Raises:

  • ValueError: if the component id cannot be extracted.

Returns:

the component id and the configuration object.

validate_component_configuration

@classmethod
def validate_component_configuration(cls,
                                     component_id: ComponentId,
                                     configuration: Dict,
                                     env_vars_friendly: bool = False) -> None

Validate the component configuration of an agent configuration file.

This check is to detect inconsistencies in the specified fields.

Arguments:

  • component_id: the component id.
  • configuration: the configuration dictionary.
  • env_vars_friendly: bool, if set True, will not raise errors over the env variable definitions.

Raises:

  • ValueError: if the configuration is not valid.

validate

def validate(json_data: Dict) -> None

Validate a JSON object against the right JSON schema.

Arguments:

  • json_data: the JSON data.

validate_agent_components_configuration

def validate_agent_components_configuration(
        component_configurations: Dict) -> None

Validate agent component configurations overrides.

Arguments:

  • component_configurations: the component configurations to validate.

required_fields

@property
def required_fields() -> List[str]

Get the required fields.

Returns:

list of required fields.

validate_data_with_pattern

def validate_data_with_pattern(data: dict,
                               pattern: dict,
                               excludes: Optional[List[Tuple[str]]] = None,
                               skip_env_vars: bool = False) -> List[str]

Validate data dict with pattern dict for attributes present and type match.

Arguments:

  • data: data dict to validate
  • pattern: dict with pattern to check over
  • excludes: list of tuples of str of paths to be skipped during the check
  • skip_env_vars: is set True will not check data type over env variables.

Returns:

list of str with error descriptions

filter_data

def filter_data(base: Any, updates: Any) -> Any

Return difference in values or SAME_MARK object if values are the same.