Source code for horizon.utils.validators

# Copyright 2012 Nebula, Inc.
#
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
#    not use this file except in compliance with the License. You may obtain
#    a copy of the License at
#
#         http://www.apache.org/licenses/LICENSE-2.0
#
#    Unless required by applicable law or agreed to in writing, software
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
#    License for the specific language governing permissions and limitations
#    under the License.

import re

from oslo_utils import netutils

from django.core.exceptions import ValidationError  # noqa
from django.core import validators  # noqa
from django.utils.translation import ugettext_lazy as _

from horizon import conf


[docs]def validate_port_range(port): if not netutils.is_valid_port(port): raise ValidationError(_("Not a valid port number"))
[docs]def validate_icmp_type_range(icmp_type): if not netutils.is_valid_icmp_type(icmp_type): if icmp_type == -1: return raise ValidationError(_("Not a valid ICMP type"))
[docs]def validate_icmp_code_range(icmp_code): if not netutils.is_valid_icmp_code(icmp_code): if icmp_code == -1: return raise ValidationError(_("Not a valid ICMP code"))
[docs]def validate_ip_protocol(ip_proto): if ip_proto not in range(0, 256): raise ValidationError(_("Not a valid IP protocol number"))
[docs]def password_validator(): return conf.HORIZON_CONFIG["password_validator"]["regex"]
[docs]def password_validator_msg(): return conf.HORIZON_CONFIG["password_validator"]["help_text"]
[docs]def validate_port_or_colon_separated_port_range(port_range): """Accepts a port number or a single-colon separated range.""" if port_range.count(':') > 1: raise ValidationError(_("One colon allowed in port range")) ports = port_range.split(':') for port in ports: validate_port_range(port)
[docs]def validate_metadata(value): error_msg = _('Invalid metadata entry. Use comma-separated' ' key=value pairs') if value: specs = value.split(",") for spec in specs: keyval = spec.split("=") # ensure both sides of "=" exist, but allow blank value if not len(keyval) == 2 or not keyval[0]: raise ValidationError(error_msg) # Same as POSIX [:print:]. Accordingly, diacritics are disallowed.
PRINT_REGEX = re.compile(r'^[\x20-\x7E]*$') validate_printable_ascii = validators.RegexValidator( PRINT_REGEX, _("The string may only contain ASCII printable characters."), "invalid_characters")

Project Source