diff --git a/libcove/lib/common.py b/libcove/lib/common.py index beb22c1..97c37f9 100644 --- a/libcove/lib/common.py +++ b/libcove/lib/common.py @@ -29,23 +29,29 @@ uniqueItemsValidator = validator.VALIDATORS.pop("uniqueItems") LANGUAGE_RE = re.compile("^(.*_(((([A-Za-z]{2,3}(-([A-Za-z]{3}(-[A-Za-z]{3}){0,2}))?)|[A-Za-z]{4}|[A-Za-z]{5,8})(-([A-Za-z]{4}))?(-([A-Za-z]{2}|[0-9]{3}))?(-([A-Za-z0-9]{5,8}|[0-9][A-Za-z0-9]{3}))*(-([0-9A-WY-Za-wy-z](-[A-Za-z0-9]{2,8})+))*(-(x(-[A-Za-z0-9]{1,8})+))?)|(x(-[A-Za-z0-9]{1,8})+)))$") # noqa -validation_error_template_lookup = {'date-time': 'Date is not in the correct format', - 'uri': 'Invalid \'uri\' found', - 'string': '\'{}\' is not a string. Check that the value {} has quotes at the start and end. Escape any quotes in the value with \'\\\'', # noqa - 'integer': '\'{}\' is not a integer. Check that the value {} doesn’t contain decimal points or any characters other than 0-9. Integer values should not be in quotes. ', # noqa - 'number': '\'{}\' is not a number. Check that the value {} doesn’t contain any characters other than 0-9 and dot (\'.\'). Number values should not be in quotes. ', # noqa - 'object': '\'{}\' is not a JSON object', - 'array': '\'{}\' is not a JSON array'} +validation_error_template_lookup = { + 'date': 'Date is not in the correct format. The correct format is YYYY-MM-DD.', + 'date-time': 'Date is not in the correct format. The correct format is YYYY-MM-DDThh:mm:ssZ.', + 'uri': 'Invalid uri found', + 'string': '\'{}\' should be a string. Check that the value {} has quotes at the start and end. Escape any quotes in the value with \'\\\'', # noqa + 'integer': '\'{}\' should be an integer. Check that the value {} doesn’t contain decimal points or any characters other than 0-9. Integer values should not be in quotes. ', # noqa + 'number': '\'{}\' should be a number. Check that the value {} doesn’t contain any characters other than 0-9 and dot (\'.\'). Number values should not be in quotes. ', # noqa + 'boolean': '\'{}\' should be a JSON boolean, \'true\' or \'false\'.', # noqa + 'object': '\'{}\' should be a JSON object', + 'array': '\'{}\' should be a JSON array. Check that value(s) appear within square brackets, [...]'} # These are "safe" html that we trust # Don't insert any values into these strings without ensuring escaping # e.g. using django's format_html function. -validation_error_template_lookup_safe = {'date-time': 'Date is not in the correct format', - 'uri': 'Invalid \'uri\' found', - 'string': '{} is not a string. Check that the value {} has quotes at the start and end. Escape any quotes in the value with \', # noqa - 'integer': '{} is not a integer. Check that the value {} doesn’t contain decimal points or any characters other than 0-9. Integer values should not be in quotes. ', # noqa - 'number': '{} is not a number. Check that the value {} doesn’t contain any characters other than 0-9 and dot (.). Number values should not be in quotes. ', # noqa - 'object': '{} is not a JSON object', - 'array': '{} is not a JSON array'} +validation_error_template_lookup_safe = { + 'date': 'Date is not in the correct format. The correct format is YYYY-MM-DD.', + 'date-time': 'Date is not in the correct format. The correct format is YYYY-MM-DDT00:00:00Z.', + 'uri': 'Invalid uri found', + 'string': '{} should be a string. Check that the value {} has quotes at the start and end. Escape any quotes in the value with \', # noqa + 'integer': '{} should be an integer. Check that the value {} doesn’t contain decimal points or any characters other than 0-9. Integer values should not be in quotes. ', # noqa + 'number': '{} should be a number. Check that the value {} doesn’t contain any characters other than 0-9 and dot (.). Number values should not be in quotes. ', # noqa + 'boolean': '{} should be a JSON boolean, true or false.', # noqa + 'object': '{} should be a JSON object', + 'array': '{} should be a JSON array. Check that value(s) appear within square brackets, [...]'} def unique_ids(validator, ui, instance, schema): @@ -519,7 +525,10 @@ def get_schema_validation_errors(json_data, schema_obj, schema_name, cell_src_ma header = value.get('header') if not header and len(e.path): - header = e.path[-1] + if isinstance(e.path[-1], int) and len(e.path) >= 2: + header = '{}/{}'.format(e.path[-2], e.path[-1]) + else: + header = e.path[-1] validator_type = e.validator if e.validator in ('format', 'type'): @@ -562,26 +571,38 @@ def get_schema_validation_errors(json_data, schema_obj, schema_name, cell_src_ma field_name = heading[0][1] value['header'] = heading[0][1] if parent_name: - message = "'{}' is missing but required within '{}'".format(field_name, parent_name) - message_safe = format_html("{} is missing but required within {}", field_name, parent_name) # noqa + message = "'{}' is missing but required within '{}'. Check that the field is included and correctly spelled.".format(field_name, parent_name) + message_safe = format_html("{} is missing but required within {}. Check that the field is included and correctly spelled.", field_name, parent_name) # noqa else: - message = "'{}' is missing but required".format(field_name) - message_safe = format_html("{} is missing but required", field_name, parent_name) + message = "'{}' is missing but required. Check that the field is included and correctly spelled.".format(field_name) + message_safe = format_html("{} is missing but required. Check that the field is included and correctly spelled.", field_name, parent_name) if e.validator == 'enum': if "isCodelist" in e.schema: continue - message = "Invalid code found in '{}'".format(header) - message_safe = format_html("Invalid code found in {}", header) + message = "'{}' contains an unrecognised value. Check the related codelist for allowed code values.".format(header) + message_safe = format_html("{} contains an unrecognised value. Check the related codelist for allowed code values.", header) if e.validator == 'pattern': message_safe = format_html('{} does not match the regex {}', header, e.validator_value) # noqa if e.validator == 'minItems' and e.validator_value == 1: - message_safe = format_html('{} is too short. You must supply at least one value, or remove the item entirely (unless it’s required).', e.instance) # noqa + message_safe = format_html('{} is too short. You must supply at least one value, or remove the item entirely (unless it’s required).', header) # noqa - if e.validator == 'minLength' and e.validator_value == 1: - message_safe = format_html('"{}" is too short. Strings must be at least one character. This error typically indicates a missing value.', e.instance) # noqa + if e.validator == 'minLength': + if e.validator_value == 1: + message_safe = format_html('"{}" is too short. Strings must be at least one character. This error typically indicates a missing value.', header) # noqa + else: + message_safe = format_html('{} is too short. It should be at least {} characters.', header, e.validator_value) # noqa + + if e.validator == 'maxLength': + message_safe = format_html('{} is too long. It should not exceed {} characters.', header, e.validator_value) # noqa + + if e.validator == 'minimum': + message_safe = format_html('{} is too small. The minimum allowed value is {}.', header, e.validator_value) # noqa + + if e.validator == 'maximum': + message_safe = format_html('{} is too large. The maximum allowed value is {}.', header, e.validator_value) # noqa if message_safe is None: message_safe = escape(message)