
django.utils.translation.ugettext(), ugettext_lazy(), ugettext_noop(), ungettext(), and ungettext_lazy() are deprecated in favor of the functions that they’re aliases for: django.utils.translation.gettext(), gettext_lazy(), gettext_noop(), ngettext(), and ngettext_lazy(). https://docs.djangoproject.com/en/4.0/releases/3.0/#id3 Change-Id: I77878f84e9d10cf6a136dada81eabf4e18676250
87 lines
2.6 KiB
Python
87 lines
2.6 KiB
Python
# 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
|
|
from django.core import validators
|
|
from django.utils.translation import gettext_lazy as _
|
|
|
|
from horizon import conf
|
|
|
|
|
|
def validate_port_range(port):
|
|
if not netutils.is_valid_port(port):
|
|
raise ValidationError(_("Not a valid port number"))
|
|
|
|
|
|
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"))
|
|
|
|
|
|
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"))
|
|
|
|
|
|
def validate_ip_protocol(ip_proto):
|
|
if ip_proto < -1 or ip_proto > 255:
|
|
raise ValidationError(_("Not a valid IP protocol number"))
|
|
|
|
|
|
def password_validator():
|
|
return conf.HORIZON_CONFIG["password_validator"]["regex"]
|
|
|
|
|
|
def password_validator_msg():
|
|
return conf.HORIZON_CONFIG["password_validator"]["help_text"]
|
|
|
|
|
|
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)
|
|
|
|
|
|
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")
|