Sindbad~EG File Manager

Current Path : /lib/python3.6/site-packages/sos/report/plugins/__pycache__/
Upload File :
Current File : //lib/python3.6/site-packages/sos/report/plugins/__pycache__/foreman.cpython-36.opt-1.pyc

3

�f:�@snddlmZddlmZddlmZmZmZmZm	Z	Gdd�de�Z
Gdd�de
e�ZGdd	�d	e
ee�Zd
S)�)�match)�quote)�Plugin�RedHatPlugin�DebianPlugin�UbuntuPlugin�	PluginOptc@s�eZdZdZdZdZdZdZdZdZ	dZ
ddiZed	d
dd�ed
ddd�edddd�gZ
dZdd�Zdd�Zdd�Zd dd�Zdd�ZdS)!�Foremanz$Foreman/Satellite systems management�foremani�sysmgmtNZ	localhost��
PGPASSWORD�days�z!number of days for dynflow output)�defaultZdesc�
proxyfeaturesFz!collect features of smart proxieszpuma-gczcollect Puma GC statsz/pumactl %s -S /usr/share/foreman/tmp/puma.statec	$Cs�d}y�d}t|ddd��}|j�j�}WdQRXxv|D]n}|s6|ddkrNq6|jd�r^d	}q6|rztd
|�rz|j�d|_|r�td|�r�|j�d|_|jd
�s6d}q6WWntk
r�YnX|jjd�r�|jj	d�s�|jjd�o�|jj	d��r|jddQ�|_d|ji|_
|jddddd��|jddg�|j
d�d}|j�}|j
d�d}|j�}|jdd|j�d�gdd�|jddd d!d"d#d$d%d&d'd(d)d*d+d|j�d,�d|j�d-�d|j�d.�d/|j�d0�d/|j�d1�d|j�d2�g�|jd3d4d5d6d7d8d9d:|d:|d;g
�|jd<d=d>�|jd?d@dA�|jdBdCd>�|jdDdEd>�|jdFdG�|jdH��rp|j|jdIdJd>�|j|jdKdLd>�|jdM�|jdN�}|j|dO|j
dP�|j�|j�dS)RNFz/etc/foreman/database.yml�rzUTF-8)�encodingr�#zproduction:Tz\s+host:\s+\S+�z\s+password:\s+\S+� �"�'r
Zforeman_production_logZforeman_tasks_configZforeman_ssl_access_ssl_log)z!/var/log/foreman/production.log.*z/etc/sysconfig/foreman-tasksz/etc/sysconfig/dynflowdz)/var/log/httpd/foreman-ssl_access_ssl.logz/etc/foreman/*key.pemz/etc/foreman/encryption_key.rbZhostname�outputzhostname -fz/var/log/foreman/production.logz	/var/log/z*/foreman-ssl_*_ssl.log)�	sizelimitz
/etc/foreman/z/etc/sysconfig/foremanz/etc/sysconfig/dynflowdz/etc/default/foremanz&/var/log/foreman/dynflow_executor*log*z*/var/log/foreman/dynflow_executor*.output*z#/var/log/foreman/apipie_cache*.log*z/var/log/foreman/cron*.log*z /var/log/foreman/db_migrate*log*z/var/log/foreman/db_seed*log*z$/var/log/foreman/production.log[.-]*z$/var/log/foreman-selinux-install.logz&/var/log/foreman-proxy-certs-generate*z/usr/share/foreman/Gemfile*z
*/foreman*z&*/katello-reverse-proxy_error_ssl.log*z*/error_log*z/etc/z*/conf/z	*/conf.d/z'*/katello-reverse-proxy_access_ssl.log*zforeman-selinux-relabel -nvzpassenger-status --show poolz passenger-status --show requestsz"passenger-status --show backtraceszpassenger-memory-statszls -lanR /root/ssl-buildz(ls -lanR /usr/share/foreman/config/hookszping -c1 -W1 %szping -c1 -W1 localhostz�qpid-stat -b amqps://localhost:5671 -q                     --ssl-certificate=/etc/pki/katello/qpid_router_client.crt                     --ssl-key=/etc/pki/katello/qpid_router_client.key                     --sasl-mechanism=ANONYMOUSzqpid-stat_-q)�suggest_filenamezhammer pingZhammer_ping)Ztagszsystemctl list-units dynflow*Z
dynflow_unitsz!"system-dynflow\x2dsidekiq.slice"Zdynflow_sidekiq_statuszdynflow-sidekiq@*)Zunitszpuma-gczgc-statszpumactl_gc-statsZstatsZ
pumactl_statsz/usr/sbin/foreman-puma-statusa[SELECT table_name, pg_size_pretty(total_bytes) AS total, pg_size_pretty(index_bytes) AS INDEX , pg_size_pretty(toast_bytes) AS toast, pg_size_pretty(table_bytes) AS TABLE FROM ( SELECT *, total_bytes-index_bytes-COALESCE(toast_bytes,0) AS table_bytes FROM (SELECT c.oid,nspname AS table_schema, relname AS TABLE_NAME, c.reltuples AS row_estimate, pg_total_relation_size(c.oid) AS total_bytes, pg_indexes_size(c.oid) AS index_bytes, pg_total_relation_size(reltoastrelid) AS toast_bytes FROM pg_class c LEFT JOIN pg_namespace n ON n.oid = c.relnamespace WHERE relkind = 'r') a) a order by total_bytes DESCZforeman_db_tables_sizes)r�env���)�open�read�
splitlines�
startswithr�split�dbhost�dbpasswd�IOError�endswithr�
add_file_tagsZadd_forbidden_path�exec_cmd�stripZ
add_copy_spec�	apachepkg�add_cmd_outputZadd_service_statusZadd_journal�
get_option�pumactl�build_query_cmd�collect_foreman_db�collect_proxies)	�selfZproduction_scopeZ
foreman_db�dfileZ
foreman_lines�lineZ	_hostnameZ_host_f�_cmd�r5�/usr/lib/python3.6/foreman.py�setup(s�





z
Foreman.setupc	Csd|jd�}t|�}d}d|�d�}d|�d�}d|�d�}d	|�d�}d
}|ddd
dd|dd�}	||||d�}
x4|	j�D](\}}|j|�}
|j|
|dd|jd�q|W|jd�}xN|
j�D]B\}}d}|dkr�|r�d}|j|d|d�}
|j|
|dd|jd�q�WdS)z% Collect foreman db and dynflow data z%s daysrzRselect id,name,value from settings where name not similar to '%(pass|key|secret)%'zFselect * from foreman_tasks_tasks where started_at > NOW() - interval z order by started_at ascz�select dynflow_execution_plans.* from foreman_tasks_tasks join dynflow_execution_plans on (foreman_tasks_tasks.external_id = dynflow_execution_plans.uuid::varchar) where foreman_tasks_tasks.started_at > NOW() - interval z, order by foreman_tasks_tasks.started_at ascz�select dynflow_actions.* from foreman_tasks_tasks join dynflow_actions on (foreman_tasks_tasks.external_id = dynflow_actions.execution_plan_uuid::varchar) where foreman_tasks_tasks.started_at > NOW() - interval z�select dynflow_steps.* from foreman_tasks_tasks join dynflow_steps on (foreman_tasks_tasks.external_id = dynflow_steps.execution_plan_uuid::varchar) where foreman_tasks_tasks.started_at > NOW() - interval z�WITH prefix_counts AS (SELECT split_part(name,'::',1) FROM fact_names) SELECT COUNT(*), split_part AS "fact_name_prefix" FROM prefix_counts GROUP BY split_part ORDER BY count DESC LIMIT 100zselect * from schema_migrationsz`select id,type,name,host,port,account,base_dn,attr_login,onthefly_register,tls from auth_sourcesz!select * from dynflow_schema_infozselect count(*) from auditszselect count(*) from logsz select name,url,download_policy zfrom smart_proxies)Zforeman_settings_tableZforeman_schema_migrationsZforeman_auth_tableZdynflow_schema_infoZaudits_table_countZlogs_table_countZfact_names_prefixesZ
smart_proxies)�foreman_tasks_tasksZdynflow_execution_plansZdynflow_actionsZ
dynflow_stepsiX�d)r�timeoutrrz
dynflow-utils�psqlr8z /usr/libexec/psql-msgpack-decodeT)�csv�binaryNz2select name,url,download_policy from smart_proxies)r,r�itemsr.r+rZis_installed)r1rZintervalZscmdZdtaskcmdZdyncmdZ
dactioncmdZ	dstepscmdZfactnamescmdZ	foremandbZ
foremancsv�table�valr4ZdynutilsZdynr=r5r5r6r/�sB	



zForeman.collect_foreman_dbcCs�|jd�r~|jddd�}|j||jd�}|ddkr~xH|dj�d	d
�D]0}|jd�}d|d	}|j||dd
dd�qJW|jddg�d
S)z Collect foreman proxies rz"select name,url from smart_proxiesT)r<)rZstatusrrrN�,z\curl -s --key /etc/foreman/client_key.pem --cert /etc/foreman/client_cert.pem %s/v2/featuresZsmart_proxies_features�
)rZsubdirr:Z
http_proxyZhttps_proxy)r,r.r(rr r"r+Zadd_env_var)r1r4Zproxies�proxyr5r5r6r0s


zForeman.collect_proxiesr;cCs$|rd|}d}|||jt|�fS)aI
        Builds the command needed to invoke the pgsql query as the postgres
        user.
        The query requires significant quoting work to satisfy both the
        shell and postgres parsing requirements. Note that this will generate
        a large amount of quoting in sos logs referencing the command being run
        z>COPY (%s) TO STDOUT WITH (FORMAT 'csv', DELIMITER ',', HEADER)z:%s --no-password -h %s -p 5432 -U foreman -d foreman -c %s)r#r)r1Zqueryr<r=Z_dbcmdr5r5r6r.)s
zForeman.build_query_cmdcCs |jddd�|jddd�dS)Nz/etc/foreman/(.*)((conf)(.*)?)z5((\:|\s*)(passw|cred|token|secret|key).*(\:\s|=))(.*)z
\1********z"/etc/foreman/(.*)((yaml|yml)(.*)?)z\1"********")Zdo_path_regex_sub)r1r5r5r6�postproc7szForeman.postproc)r)r
)Fr;)�__name__�
__module__�__qualname__Z
short_descZplugin_nameZplugin_timeoutZprofilesZpackagesr*r#r$rrZoption_listr-r7r/r0r.rDr5r5r5r6r	s,
Z
r	cs eZdZdZ�fdd�Z�ZS)�
RedHatForemanZhttpdcs&|jddi�t�j�|jd�dS)Nz"/usr/share/foreman/.ssh/ssh_configZssh_foreman_configzgem list)r'�superr7r+)r1)�	__class__r5r6r7Js

zRedHatForeman.setup)rErFrGr*r7�
__classcell__r5r5)rJr6rHFsrHc@seZdZdZdS)�
DebianForemanZapache2N)rErFrGr*r5r5r5r6rLTsrLN)
�rerZshlexrZsos.report.pluginsrrrrrr	rHrLr5r5r5r6�<module>s6

Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists