HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //lib/python3/dist-packages/cloudinit/sources/__pycache__/DataSourceCloudStack.cpython-38.pyc
U

Ӈg�,�@s�ddlZddlZddlZddlmZddlmZmZmZddl	m
Z
ddlmZm
Z
ddlmZddlmZddlmZdd	lmZe�e�ZGd
d�d�ZGdd
�d
ej�Zdd�Zdd�Zdd�ZeejejffgZ dd�Z!dS)�N)�suppress)�gaierror�getaddrinfo�	inet_ntoa)�pack)�sources�subp)�
url_helper)�util)�dhcp)�ec2c@s(eZdZdZdd�Zdd�Zdd�ZdS)	�CloudStackPasswordServerClienta�
    Implements password fetching from the CloudStack password server.

    http://cloudstack-administration.readthedocs.org/
       en/latest/templates.html#adding-password-management-to-your-templates
    has documentation about the system.  This implementation is following that
    found at
    https://github.com/shankerbalan/cloudstack-scripts/
       blob/master/cloud-set-guest-password-debian
    cCs
||_dS�N)�virtual_router_address)�selfr�r�H/usr/lib/python3/dist-packages/cloudinit/sources/DataSourceCloudStack.py�__init__+sz'CloudStackPasswordServerClient.__init__cCs:t�ddddddddd	d
�|�d�|j�g�\}}|��S)NZwgetz--quietz--tries�3z	--timeoutZ20z--output-document�-z--headerzDomU_Request: {0}z{0}:8080)r�formatr�strip)rZdomu_request�output�_rrr�_do_request.s
��z*CloudStackPasswordServerClient._do_requestcCs4|�d�}|dkrdS|dkr&td��|�d�|S)NZsend_my_password)��saved_passwordZbad_requestz-Error when attempting to fetch root password.r)r�RuntimeError)r�passwordrrr�get_passwordCs

z+CloudStackPasswordServerClient.get_passwordN)�__name__�
__module__�__qualname__�__doc__rrrrrrrr
sr
csfeZdZdZdZdZdd�Zdd�Zd�fd	d
�	Zdd�Z	d
d�Z
dd�Zdd�Ze
dd��Z�ZS)�DataSourceCloudStackZ
CloudStack�x�2cCsdtj�||||�tj�|jd�|_d|_||_t	|j�|_
|j
sJtd��d|j
�d�|_i|_
dS)NZcsZlatestzNo virtual router found!zhttp://�/)r�
DataSourcer�os�path�join�seed_dir�api_ver�distro�get_vr_address�vr_addrr�metadata_address�cfg)rZsys_cfgr.�pathsrrrrUszDataSourceCloudStack.__init__c
Cs�t�d�t�d�}|r|St�d�ttj��,t���|jd�}|rX|W5QR�SW5QRXt�d|jj	j
�tt��2|jj	�|jj
�}|�d�p�d}|W5QR�SQRXt�d�dS)z�
        Try obtaining a "domain-name" DHCP lease parameter:
        - From systemd-networkd lease
        - From dhclient lease
        z.Try obtaining domain name from networkd leasesZ
DOMAINNAMEzHCould not obtain FQDN from networkd leases. Falling back to ISC dhclientzdomain-namezBCould not obtain FQDN from ISC dhclient leases. Falling back to %sNzNo dhcp leases found)�LOG�debugr�networkd_get_option_from_leasesr�NoDHCPLeaseMissingDhclientError�IscDhclient�get_key_from_latest_leaser.�dhcp_client�client_name�FileNotFoundError�get_newest_leaseZfallback_interface�get)r�
domainnameZdomain_name�latest_leaserrr�_get_domainnamecs4

���
�
z$DataSourceCloudStack._get_domainnameFcsnt��|||�}|rjd|jkrjt�d�|��}|r^|j�d|��}t�d|�t�||j�St�d|�|S)z�
        Returns instance's hostname / fqdn
        First probes the parent class method.

        If fqdn is requested, and the parent method didn't return it,
        then attach the domain-name from DHCP response.
        �.zFQDN requestedzObtained the following FQDN: %szNCould not determine domain name for FQDN. Fall back to hostname as an FQDN: %s)	�super�get_hostname�hostnamer4r5rArZDataSourceHostnameZ
is_default)rZfqdnZ
resolve_ipZ
metadata_onlyrEr?��	__class__rrrD�s

�z!DataSourceCloudStack.get_hostnamecCs~|��}|jdkrdSt�|jd�g}t��}tj||j|jt	j
d�\}}|r\t	�d|�nt	�d|t
t��|��t|�S)NrFzlatest/meta-data/instance-id)�urlsZmax_waitZtimeoutZ	status_cbzUsing metadata source: '%s'z>Giving up on waiting for the metadata from %s after %s seconds)Zget_url_paramsZmax_wait_seconds�uhelpZcombine_urlr1�time�	monotonicZwait_for_urlZtimeout_secondsr4Zwarningr5Zcritical�int�bool)rZ
url_paramsrH�
start_timeZurlZ	_responserrr�wait_for_metadata_service�s.
���
�z.DataSourceCloudStack.wait_for_metadata_servicecCs|jSr)r2�rrrr�get_config_obj�sz#DataSourceCloudStack.get_config_objcCsi}tj||jdd�r>|d|_|d|_t�d|j�dSz�|��sNWdSt�	�}t
�|j|j
�|_t
�|j|j
�|_t�dtt�	�|��t|j�}z|��}Wn$tk
r�t�td	|j�YnX|r�d|d
did�|_WdStk
�rt�td|j
�YdSXdS)
Nr')�basez	user-dataz	meta-dataz%Using seeded cloudstack data from: %sTFz)Crawl of metadata service took %s secondsz/Failed to fetch password from virtual router %sZexpire)Z
ssh_pwauthrZchpasswdz(Failed fetching from metadata service %s)r
Zread_optional_seedr,Zuserdata_raw�metadatar4r5rOrJrKrZget_instance_userdatar-r1Zget_instance_metadatarLr
r0r�	ExceptionZlogexcr2)rZseed_retrNZpassword_clientZset_passwordrrr�	_get_data�s\

���
�
���zDataSourceCloudStack._get_datacCs
|jdS)Nzinstance-id�rSrPrrr�get_instance_id�sz$DataSourceCloudStack.get_instance_idcCs
|jdS)Nzavailability-zonerVrPrrr�availability_zone�sz&DataSourceCloudStack.availability_zone)FFF)r r!r"ZdsnameZurl_max_waitZurl_timeoutrrArDrOrQrUrW�propertyrX�
__classcell__rrrFrr$Ms,�0r$cCsDztdd�}Wn tk
r.t�d�YdSX|dddSdS)Nzdata-server�PzDNS Entry data-server not foundr�)rrr4r5)Zaddrinforrr�get_data_servers
r]cCs^t�d���}|D]F}|�d�}|ddkrttdt|dd���}t�d|�|SqdS)	Nz/proc/net/route�	�Z00000000z<L��z"Found default route, gateway is %s)	r
Zload_text_file�
splitlines�splitrrrLr4r5)�lines�line�itemsZgwrrr�get_default_gateways

rgc
Cs�t�}|rt�d|�|St�d�}|r8t�d|�|Sttj��6t���|d�}|rtt�d|�|W5QR�SW5QRXtt	��8|j
�|�}|r�t�d||j
j�|W5QR�SW5QRXt�d�t
�S)Nz4Found metadata server '%s' via data-server DNS entryZSERVER_ADDRESSz-Found SERVER_ADDRESS '%s' via networkd_leaseszdhcp-server-identifierz&Found SERVER_ADDRESS '%s' via dhclientz1Found SERVER_ADDRESS '%s' via ephemeral %s lease z$No DHCP found, using default gateway)r]r4r5rr6rr7r8r9r<r:r=r;rg)r.Zlatest_addressr@rrrr/sB�
��
�
r/cCst�|t�Sr)rZlist_from_depends�datasources)Zdependsrrr�get_datasource_listRsri)"Zloggingr)rJ�
contextlibrZsocketrrrZstructrZ	cloudinitrrr	rIr
Z
cloudinit.netrZcloudinit.sources.helpersrZ	getLoggerr r4r
r(r$r]rgr/ZDEP_FILESYSTEMZDEP_NETWORKrhrirrrr�<module>s(
.7
2�