
    Vh                     n    d Z ddlmZmZmZ ddlmZmZ ddlm	Z	 e
ZdZdZdZed        Z G d	 d
e      Zy)z2
Test plugin file for netaddr tests: ipv6_address
    )absolute_importdivisionprint_function)_need_ipaddress
ip_address)_validate_argsa9  
    name: ipv6_address
    author: Priyam Sahoo (@priyamsahoo)
    version_added: "2.2.0"
    short_description: Test if something is an IPv6 address
    description:
        - This plugin checks if the provided value is a valid host IP address with IPv6 addressing scheme
    options:
        ip:
            description:
            - A string that represents the value against which the test is going to be performed
            - 'For example: C(10.1.1.1), C(10.0.0.0/8), or C(fe80::216:3eff:fee4:16f3)'
            type: str
            required: True
    notes:
aR  

#### Simple examples

- name: Check if fe80::216:3eff:fee4:16f3 is a valid IPv6 address
  ansible.builtin.set_fact:
    data: "{{ 'fe80::216:3eff:fee4:16f3' is ansible.utils.ipv6_address }}"

# TASK [Check if fe80::216:3eff:fee4:16f3 is a valid IPv6 address] *********************
# ok: [localhost] => {
#     "ansible_facts": {
#         "data": true
#     },
#     "changed": false
# }

- name: Check if 2001:db8:a::123/64 is not a valid IPv6 address
  ansible.builtin.set_fact:
    data: "{{ '2001:db8:a::123/64' is not ansible.utils.ipv6_address }}"

# TASK [Check if 2001:db8:a::123/64 is not a valid IPv6 address] ***********************
# ok: [localhost] => {
#     "ansible_facts": {
#         "data": true
#     },
#     "changed": false
# }

- name: Check if 192.169.1.250 is not a valid IPv6 address
  ansible.builtin.set_fact:
    data: "{{ '192.169.1.250' is not ansible.utils.ipv6_address }}"

# TASK [Check if 192.169.1.250 is not a valid IPv6 address] ****************************
# ok: [localhost] => {
#     "ansible_facts": {
#         "data": true
#     },
#     "changed": false
# }
z
  data:
    description:
      - If jinja test satisfies plugin expression C(true)
      - If jinja test does not satisfy plugin expression C(false)
c                 |    d| i}t        dt        |       	 t        |       j                  dk(  S # t        $ r Y yw xY w)z$Test if something in an IPv6 addressipipv6_address   F)r   DOCUMENTATIONr   version	Exception)r
   paramss     k/home/dcms/DCMS/lib/python3.12/site-packages/ansible_collections/ansible/utils/plugins/test/ipv6_address.py_ipv6_addressr   W   sE     BZF>=&9"~%%** s   / 	;;c                       e Zd ZdZdeiZd Zy)
TestModuleznetwork jinja testr   c                     | j                   S )N)test_map)selfs    r   testszTestModule.testsi   s    }}    N)__name__
__module____qualname____doc__r   r   r    r   r   r   r   d   s    .Hr   r   N)r   
__future__r   r   r   Kansible_collections.ansible.utils.plugins.plugin_utils.base.ipaddress_utilsr   r   Aansible_collections.ansible.utils.plugins.plugin_utils.base.utilsr   type__metaclass__r   EXAMPLESRETURNr   objectr   r   r   r   <module>r'      s[    A @ ] "'R
 	 	 r   