Mini Shell
a
�DOg*3 � @ s� d Z dZddlZdZdZG dd� de�ZG dd � d e�Zd
d� Zd=d
d�Z dd� Z
dd� Zdd� Zdd� Z
dd� Zdd� Zdd� Zdd� Zdd � Zd!d"� ZG d#d$� d$�ZdaejG d%d&� d&e��ZejG d'd(� d(e��ZG d)d*� d*�ZG d+d,� d,ee�ZG d-d.� d.e�ZG d/d0� d0ee�ZG d1d2� d2�Zee_G d3d4� d4�ZG d5d6� d6ee�Z G d7d8� d8e �Z!G d9d:� d:ee�Z"G d;d<� d<�Z#e#e _dS )>z�A fast, lightweight IPv4/IPv6 manipulation library in Python.
This library is used to create/poke/manipulate IPv4 and IPv6 addresses
and networks.
z1.0� N� � c @ s e Zd ZdZdS )�AddressValueErrorz%A Value Error related to the address.N��__name__�
__module__�__qualname__�__doc__� r
r
�!/usr/lib64/python3.9/ipaddress.pyr s r c @ s e Zd ZdZdS )�NetmaskValueErrorz%A Value Error related to the netmask.Nr r
r
r
r r s r c C sV z
t | �W S ttfy Y n0 z
t| �W S ttfyB Y n0 t| �d���dS )a� Take an IP string/int and return an object of the correct type.
Args:
address: A string or integer, the IP address. Either IPv4 or
IPv6 addresses may be supplied; integers less than 2**32 will
be considered to be IPv4 by default.
Returns:
An IPv4Address or IPv6Address object.
Raises:
ValueError: if the *address* passed isn't either a v4 or a v6
address
z. does not appear to be an IPv4 or IPv6 addressN)�IPv4Addressr r �IPv6Address�
ValueError��addressr
r
r �
ip_address s
r Tc C sZ zt | |�W S ttfy" Y n0 zt| |�W S ttfyF Y n0 t| �d���dS )a� Take an IP string/int and return an object of the correct type.
Args:
address: A string or integer, the IP network. Either IPv4 or
IPv6 networks may be supplied; integers less than 2**32 will
be considered to be IPv4 by default.
Returns:
An IPv4Network or IPv6Network object.
Raises:
ValueError: if the string passed isn't either a v4 or a v6
address. Or if the network has host bits set.
z. does not appear to be an IPv4 or IPv6 networkN)�IPv4Networkr r �IPv6Networkr )r �strictr
r
r �
ip_network8 s r c C sV z
t | �W S ttfy Y n0 z
t| �W S ttfyB Y n0 t| �d���dS )ag Take an IP string/int and return an object of the correct type.
Args:
address: A string or integer, the IP address. Either IPv4 or
IPv6 addresses may be supplied; integers less than 2**32 will
be considered to be IPv4 by default.
Returns:
An IPv4Interface or IPv6Interface object.
Raises:
ValueError: if the string passed isn't either a v4 or a v6
address.
Notes:
The IPv?Interface classes describe an Address on a particular
Network, so they're basically a combination of both the Address
and Network classes.
z0 does not appear to be an IPv4 or IPv6 interfaceN)�
IPv4Interfacer r �
IPv6Interfacer r r
r
r �ip_interfaceU s
r c C s. z| � dd�W S ty( td��Y n0 dS )a` Represent an address as 4 packed bytes in network (big-endian) order.
Args:
address: An integer representation of an IPv4 IP address.
Returns:
The integer address packed as 4 bytes in network (big-endian) order.
Raises:
ValueError: If the integer is negative or too large to be an
IPv4 IP address.
� �bigz&Address negative or too large for IPv4N��to_bytes�
OverflowErrorr r r
r
r �v4_int_to_packedw s r c C s. z| � dd�W S ty( td��Y n0 dS )z�Represent an address as 16 packed bytes in network (big-endian) order.
Args:
address: An integer representation of an IPv6 IP address.
Returns:
The integer address packed as 16 bytes in network (big-endian) order.
� r z&Address negative or too large for IPv6Nr r r
r
r �v6_int_to_packed� s
r! c C s, t | ��d�}t|�dkr(td| ����|S )zAHelper to split the netmask and raise AddressValueError if needed�/� zOnly one '/' permitted in )�str�split�lenr )r �addrr
r
r �_split_optional_netmask� s r( c c sN t | �}t|� }}|D ]&}|j|jd kr:||fV |}|}q||fV dS )z�Find a sequence of sorted deduplicated IPv#Address.
Args:
addresses: a list of IPv#Address objects.
Yields:
A tuple containing the first and last IP addresses in the sequence.
� N)�iter�next�_ip)� addresses�it�first�last�ipr
r
r �_find_address_range� s
r2 c C s$ | dkr|S t || | d @ �� �S )z�Count the number of zero bits on the right hand side.
Args:
number: an integer.
bits: maximum number of bits to count.
Returns:
The number of zero bits on the right hand side of the number.
r r) )�min�
bit_length)�number�bitsr
r
r �_count_righthand_zero_bits� s r7 c c s� t | t�rt |t�std��| j|jkr8td| |f ��| |krHtd��| jdkrXt}n| jdkrht}ntd��| j}| j}|j}||kr�t t
||�|| d �� d �}|||| f�}|V |d|>