Spamworldpro Mini Shell
Spamworldpro


Server : Apache/2.4.52 (Ubuntu)
System : Linux webserver 6.8.0-49-generic #49~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Wed Nov 6 17:42:15 UTC 2 x86_64
User : www-data ( 33)
PHP Version : 8.1.2-1ubuntu2.21
Disable Function : NONE
Directory :  /lib/python3/dist-packages/cloudinit/net/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //lib/python3/dist-packages/cloudinit/net/__pycache__/netplan.cpython-310.pyc
o

}��f�R�@s,ddlZddlZddlZddlZddlZddlmZddlmZm	Z	m
Z
ddlmZm
Z
mZmZddlmZmZmZmZmZmZddlmZmZdZdZe�e�Zd	d
�Zde de d
efdd�Z!dd�Z"d"dd�Z#de$de%fdd�Z&de$de$de%fdd�Z'de$de$fdd�Z(Gdd�dej)�Z)d"d d!�Z*dS)#�N)�SpooledTemporaryFile)�Callable�List�Optional)�features�safeyaml�subp�util)�IPV6_DYNAMIC_TYPES�
SYS_CLASS_NET�get_devicelist�renderer�should_add_gateway_onlink_flag�subnet_is_ipv6)�NET_CONFIG_TO_V2�NetworkStatez/etc/netplan/50-cloud-init.yamls4# This is the initial network config.
# It can be overwritten by cloud-init or console-conf.
network:
    version: 2
    ethernets:
        all-en:
            match:
                name: "en*"
            dhcp4: true
        all-eth:
            match:
                name: "eth*"
            dhcp4: true
cst�fdd�|��D��S)Nc3s&�|]\}}|���r||fVqdS�N)�
startswith)�.0�key�value��match��7/usr/lib/python3/dist-packages/cloudinit/net/netplan.py�	<genexpr>,s��
�z,_get_params_dict_by_match.<locals>.<genexpr>)�dict�items)�configrrrr�_get_params_dict_by_match+s�rr�entryrc	Cs�d$dd�}g}g}g}g}|�dg�}	|	durg}	|	D]�}
|
�d�}|�d�r7|dkr/|d7}|�|d	i�q|tvrC|�d
d	i�q|dvr�d|
�d
�}d|
vr[|d|
�d�7}|
�d�r�|
�d�dd�}
t|
d|�r|t�d|
d|�d	|
d<|�|
�d|
vr�|||
�dg��7}d|
vr�|||
�dg��7}d|
vr�d}t|
�r�d|�vr�d}|�||
�d�i�|
�dg�D]*}d|�d�|�d�f}|�d�|d�}
d|vr�|
�d|�dd�i�|�|
�q�|�|�qd|v�r|�d�}|�r|d|k�rt�	d||d|�n|d|d<t
|�dk�r"|�d |i�t
|�dk�r0|�d|i�t
|�dk�rBd |i}|�d!|i�t
|�dk�r]|�d!i�}|�d"|i�|�d!|i�d#|v�rx|d#du�rz|�d#t�|�d#��i�dSdSdS)%a�This method parse a cloudinit.net.network_state dictionary (config) and
       maps netstate keys/values into a dictionary (entry) to represent
       netplan yaml. (config v1 -> netplan)

    An example config dictionary might look like:

    {'mac_address': '52:54:00:12:34:00',
     'name': 'interface0',
     'subnets': [
        {'address': '192.168.1.2/24',
         'mtu': 1501,
         'type': 'static'},
        {'address': '2001:4800:78ff:1b:be76:4eff:fe06:1000",
         'mtu': 1480,
         'netmask': 64,
         'type': 'static'}],
      'type: physical',
      'accept-ra': 'true'
    }

    An entry dictionary looks like:

    {'set-name': 'interface0',
     'match': {'macaddress': '52:54:00:12:34:00'},
     'mtu': 1501}

    After modification returns

    {'set-name': 'interface0',
     'match': {'macaddress': '52:54:00:12:34:00'},
     'mtu': 1501,
     'address': ['192.168.1.2/24', '2001:4800:78ff:1b:be76:4eff:fe06:1000"],
     'ipv6-mtu': 1480}

    � cSs*|rt|t�s	|S||vr|�|�S|gS)zT
        Helper to convert strings to list of strings, handle single string
        )�
isinstance�str�split)�obj�tokenrrr�_listifyXs
�z$_extract_addresses.<locals>._listify�subnetsN�type�dhcp�4T�dhcp6)�static�static6z%s�address�prefixz/%d�gateway�default)�via�tozAGateway %s is not contained within subnet %s, adding on-link flagzon-link�dns_nameservers�
dns_search�mtuzipv6-mtu�routesz%s/%s�network�metric�dzZNetwork config: ignoring %s device-level mtu:%s because ipv4 subnet-level mtu:%s provided.r�	addresses�nameservers�searchz	accept-ra)r!)
�getr�updater
r�LOG�debug�appendr�warning�lenr	�is_true)rr �ifnamerr'r<r8r=�
searchdomainsr(�subnet�sn_type�addr�	new_route�mtukey�route�to_net�	entry_mtu�nsrrr�_extract_addresses3s�
%



��
�
�

��rRcs<t�fdd�|��D��}t|�dkr|�d|i�dSdS)Ncs$g|]\}}|�dd��kr|�qS)zbond-masterN)r?)r�name�cfg��bond_masterrr�
<listcomp>�s
�z0_extract_bond_slaves_by_name.<locals>.<listcomp>r�
interfaces)�sortedrrEr@)rXr rV�bond_slave_namesrrUr�_extract_bond_slaves_by_name�s
���r[cs~t��d�}tj�|�sdSt�|�}|tkrdS�fdd�dD�}dd�|D�}t�	d||�|g|D]}t�
|�q5dS)Nz etc/netplan/00-snapd-config.yamlcsg|]}t��|��qSr)r�target_path�r�f��targetrrrW�s
��z"_clean_default.<locals>.<listcomp>)z-run/systemd/network/10-netplan-all-en.networkz.run/systemd/network/10-netplan-all-eth.networkz#run/systemd/generator/netplan.stampcSsg|]
}tj�|�r|�qSr)�os�path�isfiler]rrrrW�sz9removing known config '%s' and derived existing files: %s)rr\rarbrcr	�load_binary_file�KNOWN_SNAPD_CONFIGrArB�unlink)r`�tpath�content�derived�existingr^rr_r�_clean_default�s$

���rk�net_config_content�returnc
Cszddlm}ddlm}Wntyt�dt�YdSwz@tdd��1}|�	|�|�
�|�dtj
�|�}|�|�|�}|�|�|�tj�t��Wd�n1sYwYWntyy}zt�d	t|�WYd}~dSd}~wwt�d
�dS)adUse netplan.State._write_yaml_file to write netplan config

    Where netplan python API exists, prefer to use of the private
    _write_yaml_file to ensure proper permissions and file locations
    are chosen by the netplan python bindings in the environment.

    By calling the netplan API, allow netplan versions to change behavior
    related to file permissions and treatment of sensitive configuration
    under the API call to _write_yaml_file.

    In future netplan releases, security-sensitive config may be written to
    separate file or directory paths than world-readable configuration parts.
    r)�Parser)�Statez.No netplan python module. Fallback to write %sF�w��modeNzUUnable to render network config using netplan python module. Fallback to write %s. %sz0Rendered netplan config using netplan python APIT)�netplan.parserrn�
netplan.statero�ImportErrorrArB�CLOUDINIT_NETPLAN_FILEr�write�flush�seek�io�SEEK_SET�	load_yaml�import_parser_results�_write_yaml_filerarb�basename�	ExceptionrD)rlrnror^�parser�state_output_file�errr�netplan_api_write_yaml_file�sF��



������
r��cfg_filerhcCs.tj�|�sdSt�t�|��}|t�|�kS)z<Return True when new netplan config has changed vs previous.T)rarb�existsr	r|�load_text_file)r�rh�	prior_cfgrrr�has_netplan_config_changedsr�cCsHtjrdnd}tj�|�rt�|�}||@|kr|}tj|||d�dS)zDWrite netplan config to cfg_file because python API was unavailable.i�i�rqN)r�NETPLAN_CONFIG_ROOT_READ_ONLYrarbr�r	�get_permissions�
write_file)r�rhrr�current_moderrr�fallback_write_netplan_yaml s
r�c@s�eZdZdZddgZddgZddd�Zdeefd	d
�Z			dde
deeddfd
d�Z
dedefdd�Zddd�Zde
defdd�ZdS)�RendererzBRenders network information in a /etc/netplan/network.yaml format.�netplan�generate�infoNcCsT|si}|�dt�|_|�dd�|_|�dd�|_|�dd�|_|�d�p&g|_dS)N�netplan_path�netplan_header�postcmdsF�
clean_defaultTr)r?rvr�r��	_postcmdsr��	_features)�selfrrrr�__init__1szRenderer.__init__rmc
Cs�|jsEztj|jdd�\}}t�|�}|dd|_W|jStjy)Y|jSttfyD}zt�	d|�WYd}~|jSd}~ww|jS)NT��capturez
netplan.iorz-Failed to list features from netplan info: %s)
r�r�NETPLAN_INFOr	r|�ProcessExecutionError�	TypeError�KeyErrorrArB)r��	info_blob�_errr�r�rrrr:s
����zRenderer.features�
network_state�	templatescCs�tj�t�|�|j�}t�tj�|��|�	|�}|j
r|j
nd}|�d�s*|d7}||}t||�}t
|�s<t||�|jrDt|d�|j|j|d�|j|jd�dS)N��
r_)�run�config_changed)r�)rarb�joinrr\r�r	�
ensure_dir�dirname�_render_contentr��endswithr�r�r�r�rk�_netplan_generater��_net_setup_link)r�r�r�r`�fpnplanrh�header�netplan_config_changedrrr�render_network_stateHs 	




�zRenderer.render_network_stater�r�cCs8|s	t�d�dS|st�d�dStj|jdd�dS)Nz"netplan generate postcmds disabledzEskipping call to `netplan generate`. reason: identical netplan configTr�)rArBr�NETPLAN_GENERATE)r�r�r�rrrr�is
�zRenderer._netplan_generateFcCs�|s	t�d�dSdt��vrt�d�dSgd�}t}td�D]5}zt�D]}tj�	t
|�r<tj|t
|gdd�q&WdStjyU}z|}WYd}~q d}~wwt
d	�|�)
z�To ensure device link properties are applied, we poke
        udev to re-evaluate networkd .link files and call
        the setup_link udev builtin command
        z'netplan net_setup_link postcmd disabledNz
net.ifnames=0z%Predictable interface names disabled.)�udevadmztest-builtin�net_setup_link�Tr�zQ'udevadm test-builtin net_setup_link' unable to run successfully for all devices.)rArBr	�get_cmdliner��rangerrarb�islinkrrr��RuntimeError)r�r��	setup_lnk�last_exception�_�ifacer�rrrr�us4


������zRenderer._net_setup_linkc+	CsF|jdkrt�d�tjd|jiddd�Si}i}i}i}i}g}|j�dg�}|j}	|j	}
|�
�D�]�}|�d�}ttdd	�|�
���}
|
�d
�}|dkr�||
�dd�d
�}|ddurv|
�dd�}|durpd|��i|d<n|d=|d=t|
|||j�|�||i�q2|dkr�i}i}td}dD]%}t|
|�}|�
�D]\}}|�|�dd��}|dur�q�|�||i�q�q�t|�dkr�|�d|i�|
�d�r�|
d��|d<|
�d�}|dkr�t|||�t|
|||j�|�||i�q2|dk�r�|
�d�}|du�r
t�dd|�d��q2tt�|��}d|i}d}t|
|�}i}td} |�
�D]8\}}| �|�}|du�r9�q)|�||i�|dv�r`i}!|D]}"|"��\}#}$t|$�|!|#<�qI|�||!i��q)t|�dk�rp|�d|i�|
�d��r~|
d��|d<t|
|||j�|�||i�q2|d k�r�|
�d!�|
�d"�d#�}%|
�dd�}|du�r�|��|%d<t|
|%||j�|�||%i�q2|	�s�|
�r�|	|
d$�}&|||||fD] }'|'�
�D]\}(})d%|)v�s�d&|)v�r�q�|)�d%|&i��qאq�d'd(�}*|�d)�||*d*|�7}||*d+|�7}||*d,|�7}||*d-|�7}||*d.|�7}d/�|�S)0N�zV2 to V2 passthroughr9F)�explicit_start�explicit_endrXrScSs|dduS)N�r)�itrrr�<lambda>�sz*Renderer._render_content.<locals>.<lambda>r)�physicalr)�set-namer�mac_address�
macaddressr��bond)�bond_zbond-r��-r�
parameterszbond-slaves�none�bridge�bridge_portszInvalid config. The keyz'bridge_ports' is required in �.�bridge_)z	path-costz
port-priority�vlan�vlan_idzvlan-raw-device)�id�link)r<r>r=r<cSs0|rtj||idddd�}t�|d�}|gSgS)NFT)r�r��noaliasz    )r�dumps�textwrap�indent)rS�section�dump�txtrrr�_render_section!s�z1Renderer._render_content.<locals>._render_sectionznetwork:
    version: 2
�	ethernets�wifis�bonds�bridges�vlansr�)�versionrArBrr�r�_network_stater?r5�dns_searchdomains�iter_interfacesr�filterr�lowerrRrr@rr�replacerEr[rDrY�copyr$�intrCr�)+r�r�r�r�r�r�r�rhrXr=rHrrG�ifcfg�if_type�eth�macaddrr��bond_config�v2_bond_mapr�bond_params�paramr�newname�slave_interfacesr��portsr��match_prefix�params�	br_config�
v2_bridge_map�newvalue�val�port�portvalr��nscfgr��_namerTr�rrrr��s�

�


�
�





��



�
�
�
�

zRenderer._render_contentr)NN)F)�__name__�
__module__�__qualname__�__doc__r�r�r�rr#rrrrr��boolr�r�r�rrrrr�+s$
	���
�!
"r�cCs2dg}ddg}|D]
}tj|||d�sdSq	dS)Nr�z	/usr/sbinz/sbin)r>r`FT)r�which)r`�expectedr>�prrr�	available7s�r
r)+r�rz�loggingrar��tempfiler�typingrrr�	cloudinitrrrr	�
cloudinit.netr
rrr
rr�cloudinit.net.network_staterrrvre�	getLoggerrrArrrRr[rkr#rr�r�r�r�r
rrrr�<module>s2 

4


Spamworldpro Mini