Fix URL and IP address validators

The current URL and IP address validators ported from
config controller have some defficiencies.

This commit leverages django URLValidator for URL validation
and supplements the existing domain name/ip address validation
with Ansible ipaddr filter test to catch missing/future formats.

Verify the validation tasks with the following input
  - http://[2001:db8::1]:3128
  - https://test.abc.com
  - ::1
  - localhost
  - 127.0.0.1
  - fe80::100/10
  - 2001:db8:1::/64
  - "[2001:db8::1]:8080"
  - 128.224.150.0/23
  - test.abc.com
  - test.abc.com:3000
  - 2001:db8:?::/32 (failed case)

Closes-Bug: 1833710
Change-Id: Ib3345b41ab932cd434906725f709a8b9a0195e3f
Signed-off-by: Tee Ngo <Tee.Ngo@windriver.com>
This commit is contained in:
Tee Ngo 2019-06-21 11:00:24 -04:00
parent 7a9bc2f330
commit 8fa6359ba0
3 changed files with 15 additions and 25 deletions

View File

@ -13,6 +13,7 @@ Requires: python-netaddr
Requires: sshpass Requires: sshpass
Requires: python2-ptyprocess Requires: python2-ptyprocess
Requires: python2-pexpect Requires: python2-pexpect
Requires: python2-django
Requires: ansible Requires: ansible
%description %description

View File

@ -8,7 +8,7 @@
# Validate the format of docker registry/no-proxy address # Validate the format of docker registry/no-proxy address
# #
- name: Check if the supplied address is a valid domain name or ipv4 address - name: Check if the supplied address is a valid domain name or ip address
vars: vars:
script_content: | script_content: |
# Use this utility to be consistent with the current config_controller # Use this utility to be consistent with the current config_controller
@ -20,24 +20,12 @@
args: args:
executable: /usr/bin/python executable: /usr/bin/python
failed_when: false failed_when: false
register: domain_name_ipv4_check register: domain_name_ip_check
# The domain name check above should cover the domain name as well as # Do the final catch-all check using Ansible ipaddr filter to pick up
# IPv4 addressing with/without port. If it fails, check if it's ipv6 format # addresses with CIDR notation and whatever future valid formats will be.
- block: - name: Fail if the supplied address is not a valid domain name or ip address
- name: Check if the supplied address is of ipv6 with port format
set_fact:
ipv6_with_port: true
when: input_address is search("\[") and input_address is search("\]")
- name: Fail if the supplied address is not a valid ipv6
fail: fail:
msg: "{{ input_address }} is an invalid address!." msg: "{{ input_address }} is an invalid address!."
when: (not ipv6_with_port) and (input_address|ipv6 == false) when: (domain_name_ip_check.rc != 0) and
(input_address | ipaddr == false)
- name: Fail if the supplied address is not a valid ipv6 with port
fail:
msg: "{{ input_address }} is an invalid address!."
when: (ipv6_with_port) and
((input_address.split('[')[1]).split(']')[0]|ipv6 == false)
when: domain_name_ipv4_check.rc != 0

View File

@ -12,10 +12,11 @@
- name: Check if the supplied proxy is a valid URL - name: Check if the supplied proxy is a valid URL
vars: vars:
script_content: | script_content: |
# Use this utility to be consistent with the current config_controller # Make use of django URL Validator
# and sysinv from django.core.validators import URLValidator
from controllerconfig.utils import is_valid_url try:
if not is_valid_url( "{{ input_url }}" ): URLValidator()( "{{ input_url }}" )
except Exception:
raise Exception("Invalid url format!") raise Exception("Invalid url format!")
shell: "{{ script_content }}" shell: "{{ script_content }}"
args: args: