name : netplan.cpython-39.opt-1.pyc
a

'�Dg�R�@s ddlZddlZddlZddlZddlZddlmZddlmZm	Z	m
Z
ddlmZm
Z
mZmZddlmZmZmZmZmZmZddlmZmZdZdZe�e�Zd	d
�Ze e ed�dd
�Z!dd�Z"ddd�Z#e$e%d�dd�Z&e$e$e%d�dd�Z'e$e$d�dd�Z(Gdd�dej)�Z)d dd�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��9/usr/lib/python3.9/site-packages/cloudinit/net/netplan.py�	<genexpr>,s
�z,_get_params_dict_by_match.<locals>.<genexpr>)�dict�items)�configrrrr�_get_params_dict_by_match+s�r)r�entryrc	Csd$dd�}g}g}g}g}|�dg�}	|	dur2g}	|	D�]�}
|
�d�}|�d�rp|dkr`|d7}|�|d	i�q6|tvr�|�d
d	i�q6|dvr6d|
�d
�}d|
vr�|d|
�d�7}|
�d��r|
�d�dd�}
t|
d|��r�t�d|
d|�d	|
d<|�|
�d|
v�r&|||
�dg��7}d|
v�rD|||
�dg��7}d|
v�r�d}t|
��rld|�v�rld}|�||
�d�i�|
�dg�D]X}d|�d�|�d�f}|�d�|d�}
d|v�r�|
�d|�dd�i�|�|
��q�|�|�q6d|v�r<|�d�}|�r0|d|k�r0t�	d||d|�n|d|d<t
|�dk�rX|�d |i�t
|�dk�rt|�d|i�t
|�dk�r�d |i}|�d!|i�t
|�dk�r�|�d!i�}|�d"|i�|�d!|i�d#|v�r|d#du�r|�d#t�|�d#��i�dS)%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|gSdS)zT
        Helper to convert strings to list of strings, handle single string
        N)�
isinstance�str�split)�obj�tokenrrr�_listifyXs
�z$_extract_addresses.<locals>._listify�subnetsN�typeZdhcp�4TZdhcp6)ZstaticZstatic6z%s�address�prefixz/%dZgateway�default)Zvia�tozAGateway %s is not contained within subnet %s, adding on-link flagzon-link�dns_nameserversZ
dns_searchZmtuzipv6-mtu�routesz%s/%s�networkZmetric�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	Zis_true)rr�ifnamerr&r2r/r3�
searchdomainsr'ZsubnetZsn_type�addrZ	new_routeZmtukeyZrouteZto_netZ	entry_mtu�nsrrr�_extract_addresses3s�%




��



�


�r@cs8t�fdd�|��D��}t|�dkr4|�d|i�dS)Ncs$g|]\}}|�dd��kr|�qS)zbond-masterN)r5)r�name�cfg��bond_masterrr�
<listcomp>�s�z0_extract_bond_slaves_by_name.<locals>.<listcomp>r�
interfaces)�sortedrr;r6)rFrrDZbond_slave_namesrrCr�_extract_bond_slaves_by_name�s
��rHcs~t��d�}tj�|�sdSt�|�}|tkr2dS�fdd�dD�}dd�|D�}t�	d||�|g|D]}t�
|�qjdS)Nz etc/netplan/00-snapd-config.yamlcsg|]}t��|��qSr)r�target_path�r�f��targetrrrE�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�isfilerJrrrrE��z9removing known config '%s' and derived existing files: %s)rrIrNrOrPr	Zload_binary_file�KNOWN_SNAPD_CONFIGr7r8�unlink)rMZtpath�contentZderived�existingrKrrLr�_clean_default�s"

��rV)�net_config_content�returnc
Cszddlm}ddlm}Wn ty<t�dt�YdS0z�tdd��b}|�	|�|�
�|�dtj
�|�}|�|�|�}|�|�|�tj�t��Wd�n1s�0YWn6t�y�}zt�d	t|�WYd}~dSd}~00t�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)Znetplan.parserrYZ
netplan.staterZ�ImportErrorr7r8�CLOUDINIT_NETPLAN_FILEr�write�flush�seek�io�SEEK_SET�	load_yamlZimport_parser_resultsZ_write_yaml_filerNrO�basename�	Exceptionr:)rWrYrZrK�parserZstate_output_file�errr�netplan_api_write_yaml_file�s<�



�&�
rj)�cfg_filerTrXcCs.tj�|�sdSt�t�|��}|t�|�kS)z<Return True when new netplan config has changed vs previous.T)rNrO�existsr	reZload_text_file)rkrTZ	prior_cfgrrr�has_netplan_config_changedsrm)rkrTcCsHtjr
dnd}tj�|�r4t�|�}||@|kr4|}tj|||d�dS)zDWrite netplan config to cfg_file because python API was unavailable.i�i�r\N)rZNETPLAN_CONFIG_ROOT_READ_ONLYrNrOrlr	Zget_permissionsZ
write_file)rkrTr]Zcurrent_moderrr�fallback_write_netplan_yaml s
rnc@s~eZdZdZddgZddgZddd�Zeed�d	d
�Z	de
eedd�dd
�Z
eed�dd�Zddd�Ze
ed�dd�ZdS)�RendererzBRenders network information in a /etc/netplan/network.yaml format.�netplanZgenerate�infoNcCsT|si}|�dt�|_|�dd�|_|�dd�|_|�dd�|_|�d�pLg|_dS)N�netplan_path�netplan_headerZpostcmdsF�
clean_defaultTr)r5r_rrrs�	_postcmdsrt�	_features)�selfrrrr�__init__1szRenderer.__init__)rXc
Cs�|js~z0tj|jdd�\}}t�|�}|dd|_WnFtjyJYn4ttfy|}zt�	d|�WYd}~n
d}~00|jS)NT�Zcapturez
netplan.iorz-Failed to list features from netplan info: %s)
rvr�NETPLAN_INFOr	re�ProcessExecutionError�	TypeError�KeyErrorr7r8)rwZ	info_blobZ_errrqrirrrr:s
"zRenderer.features)�
network_state�	templatesrXcCs�tj�t�|�|j�}t�tj�|��|�	|�}|j
r>|j
nd}|�d�sT|d7}||}t||�}t
|�sxt||�|jr�t|d�|j|j|d�|j|jd�dS)N��
rL��run�config_changed)r�)rNrO�joinrrIrrr	Z
ensure_dir�dirname�_render_contentrs�endswithrmrjrnrtrV�_netplan_generateru�_net_setup_link)rwr~rrMZfpnplanrT�headerZnetplan_config_changedrrr�render_network_stateHs 	




�zRenderer.render_network_stater�cCs8|st�d�dS|s$t�d�dStj|jdd�dS)Nz"netplan generate postcmds disabledzEskipping call to `netplan generate`. reason: identical netplan configTry)r7r8r�NETPLAN_GENERATE)rwr�r�rrrr�is
�zRenderer._netplan_generateFcCs�|st�d�dSdt��vr,t�d�dSgd�}td�D]n}z>t�D],}tj�t	|�rHt
j
|t	|gdd�qHWq�Wq<t
jy�}z|}WYd}~q<d}~00q<td	�|�dS)
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.)Zudevadmztest-builtinZnet_setup_link�TryzQ'udevadm test-builtin net_setup_link' unable to run successfully for all devices.)
r7r8r	Zget_cmdline�rangerrNrO�islinkrrr{�RuntimeError)rwr�Z	setup_lnk�_ZifaceriZlast_exceptionrrrr�us,


�
��zRenderer._net_setup_link)r~rXc+	CsV|jdkr*t�d�tjd|jiddd�Si}i}i}i}i}g}|j�dg�}|j}	|j	}
|�
�D�]&}|�d�}ttdd	�|�
���}
|
�d
�}|dk�r||
�dd�d
�}|ddur�|
�dd�}|dur�d|��i|d<n|d=|d=t|
|||j�|�||i�qd|dk�r�i}i}td}dD]R}t|
|�}|�
�D]8\}}|�|�dd��}|du�rj�qB|�||i��qB�q,t|�dk�r�|�d|i�|
�d��r�|
d��|d<|
�d�}|dk�r�t|||�t|
|||j�|�||i�qd|dk�r.|
�d�}|du�r,t�dd|�d��qdtt�|��}d|i}d}t|
|�}i}td} |�
�D]p\}}| �|�}|du�r��qd|�||i�|dv�rdi}!|D]}"|"��\}#}$t|$�|!|#<�q�|�||!i��qdt|�dk�r�|�d|i�|
�d��r|
d��|d<t|
|||j�|�||i�qd|d krd|
�d!�|
�d"�d#�}%|
�dd�}|du�rn|��|%d<t|
|%||j�|�||%i�qd|	�s�|
�r�|	|
d$�}&|||||fD]@}'|'�
�D]0\}(})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 passthroughr0F)�explicit_start�explicit_endrFrAcSs|dduS)N�r)�itrrr�<lambda>�rQz*Renderer._render_content.<locals>.<lambda>r(Zphysicalr)�set-namerZmac_addressZ
macaddressr��bond)Zbond_zbond-r��-r�
parameterszbond-slavesZnone�bridge�bridge_portszInvalid config. The keyz'bridge_ports' is required in �.Zbridge_)z	path-costz
port-priority�vlanZvlan_idzvlan-raw-device)�id�link)r2r4r3r2cSs0|r,tj||idddd�}t�|d�}|gSgS)NFT)r�r�Znoaliasz    )r�dumps�textwrap�indent)rA�section�dumpZtxtrrr�_render_section s�z1Renderer._render_content.<locals>._render_sectionznetwork:
    version: 2
�	ethernets�wifis�bonds�bridges�vlansr�)�versionr7r8rr�rZ_network_stater5r.Zdns_searchdomainsZiter_interfacesr�filterr�lowerr@rr6rr�replacer;rHr:rG�copyr#�intr9r�)+rwr~r�r�r�r�r�rTrFr3r=rr<ZifcfgZif_typeZethZmacaddrr�Zbond_configZv2_bond_maprZbond_paramsZparamrZnewnameZslave_interfacesr�Zportsr�Zmatch_prefix�paramsZ	br_configZ
v2_bridge_mapZnewvalue�val�portZportvalr�Znscfgr��_namerBr�rrrr��s�

�



�








��



�


zRenderer._render_content)N)NN)F)�__name__�
__module__�__qualname__�__doc__r�rzrxrr"rrrrr��boolr�r�r�rrrrro+s
	��!
!rocCs2dg}ddg}|D]}tj|||d�sdSqdS)Nrpz	/usr/sbinz/sbin)r4rMFT)r�which)rMZexpectedr4�prrr�	available6sr�)N)N)+r�rcZloggingrNr�Ztempfiler�typingrrrZ	cloudinitrrrr	Z
cloudinit.netr
rrr
rrZcloudinit.net.network_staterrr_rRZ	getLoggerr�r7rrr@rHrVr"r�rjrmrnror�rrrr�<module>s0 

4


© 2025 Cubjrnet7