%PDF- %PDF-
Direktori : /lib/python3/dist-packages/sos/cleaner/mappings/__pycache__/ |
Current File : //lib/python3/dist-packages/sos/cleaner/mappings/__pycache__/ip_map.cpython-312.pyc |
� i��d� � �6 � d dl Z d dlZd dlmZ G d� de� Zy)� N)�SoSMapc �\ � e Zd ZdZg d�Zi ZdZg d�ZdZd� Z d� Z d� Zd � Zd � Z d� Zd� Zd � Zy)�SoSIPMapa� A mapping store for IP addresses Each IP address added to this map is chcked for subnet membership. If that subnet already exists in the map, then IP addresses are deterministically generated sequentially within that subnet. For example, if a given IP is matched to subnet 192.168.1.0/24 then 192.168.1 may be obfuscated to 100.11.12.0/24. Each IP address in the original 192.168.1.0/24 subnet will then be assigned an address in 100.11.12.0/24 sequentially, such as 100.11.12.1, 100.11.12.2, etc... Internally, the ipaddress library is used to manipulate the address objects however, when retrieved by SoSCleaner any values will be strings. )z127.*z::1z0\.(.*)?z1\.(.*)?z8.8.8.8z8.8.4.4z 169.254.*z255.*�d )�127�169�172�192Fc � � | j j � D ]6 }t |� j d� d |j d� d k( s�6 y y)a There are multiple ways in which an ip address could be handed to us in a way where we're matching against a previously obfuscated address. Here, match the ip address to any of the obfuscated addresses we've already created �/r TF)�dataset�values�str�split)�self�ipaddr�_ips �=/usr/lib/python3/dist-packages/sos/cleaner/mappings/ip_map.py� ip_in_datasetzSoSIPMap.ip_in_dataset1 sQ � � �<�<�&�&�(� �C��6�{� � ��%�a�(�C�I�I�c�N�1�,=�=�� � � c �� � d}|j |� r |j dj |� � }|| j j � v r| j | S | j |� s| j |� r|S d|vrS| j j � D ]6 }|j |� s�| j | j d� d c S | j |� S )zEnsure that when requesting an obfuscated address, we return a str object instead of an IPv(4|6)Address object )r �=�]�)� r r ) � startswith�lstrip�joinr �keys�ignore_itemr r �add)r r � filt_start�keys r �getzSoSIPMap.get= s� � � *� ����Z�(��]�]�2�7�7�:�#6�7�F��T�\�\�&�&�(�(��<�<��'�'����F�#�t�'9�'9�&�'A��M� �f���|�|�(�(�*� ;���>�>�&�)��<�<��,�2�2�3�7��:�:� ;� �x�x���r c �� � g }| j D ]D }|j |j k( r ||_ y|j |v s�4|j |� �F |r|j d� d�� |d |_ yy)a/ Determine if a given address is in a subnet of an already obfuscated network and if it is, then set the address' network to the network object we're tracking. This allows us to match ip addresses with or without a CIDR notation and maintain proper network relationships. Nc � � | j S )N)� prefixlen)�ns r �<lambda>z;SoSIPMap.set_ip_cidr_from_existing_subnet.<locals>.<lambda>h s � �A�K�K� r T)r# �reverser )� _networks�ip�broadcast_address�network�append�sort)r �addr�nets�nets r � set_ip_cidr_from_existing_subnetz)SoSIPMap.set_ip_cidr_from_existing_subnetV su � � ���>�>� !�C��w�w�#�/�/�/�"�����w�w�#�~����C� � !� ��I�I�/��I�>���7�D�L� r c �0 � t j |� }|j }t |j � dk( r| j |� n| j |� | j |� S # t $ r | j j |� � w xY w)ziGiven an IP address, sanitize it to an obfuscated network or host address as appropriate z255.255.255.255)� ipaddress�ip_interface� ValueError�ignore_matchesr/ r. r �netmaskr4 �sanitize_network�sanitize_ipaddr)r �itemr1 r. s r � sanitize_itemzSoSIPMap.sanitize_itemk s� � � ��)�)�$�/�D� �,�,���w����#4�4� �1�1�$�7� �!�!�'�*��#�#�D�)�)��! � ����&�&�t�,�� �s �A/ �/&Bc �D � || j vr| j |� yy)zObfuscate the network address provided, and if there are host bits in the address then obfuscate those as well N)r+ �_new_obfuscated_network)r r. s r r; zSoSIPMap.sanitize_network� s# � � �$�.�.�(��(�(��1� )r c �x � |j | j v r�| j |j }|j |j j k( rt |j � S |j � D ]/ }| j |� r�t |� �d|j ��c S | j � S )zEObfuscate the IP address within the known obfuscated network r ) r. r+ r, r- r �hostsr r'