o
    *bG  ã                   @   s6   d dl mZmZmZ d dlmZ G dd„ deeƒZdS )é    )ÚPluginÚRedHatPluginÚSoSPredicate)Úglobc                   @   sX   e Zd ZdZdZdZdZdZdZdZ	dd„ Z
d	d
„ Zdd„ Zdd„ Zdd„ Zdd„ ZdS )ÚIpazIdentity, policy, auditZipa)ÚidentityZapacheF)z/etc/ipa)ú
ipa-serverz
ipa-clientúfreeipa-serverzfreeipa-clientc                 C   s>   |   d¡s|  d¡s|  d¡rdS |   d¡s|  d¡rdS d S )Nz
pki-serverz/var/lib/pkiz/usr/share/doc/ipa-server-4.2.0Úv4z
pki-commonz/var/lib/pki-ca/Úv3)Úis_installedÚpath_exists©Úself© r   ú8/usr/lib/python3/dist-packages/sos/report/plugins/ipa.pyÚcheck_ipa_server_version   s   
ÿþ
ÿzIpa.check_ipa_server_versionc                 C   s(   |   d| j ¡s|   d| j ¡rdS d S )Nz%s/conf/ca/CS.cfgz%s/conf/CS.cfgT)r   Úpki_tomcat_dir_v4Úpki_tomcat_dir_v3r   r   r   r   Úca_installed&   s
   ÿþzIpa.ca_installedc                 C   s   |   d¡s
|   d¡rdS d S )Nr   r	   T)r   r   r   r   r   Úipa_server_installed,   s
   
ÿþzIpa.ipa_server_installedc                 C   s8   |dkr|   g d¢¡ d S |dkr|   g d¢¡ d S d S )Nr
   )
z!/var/log/pki/pki-tomcat/ca/debug*z!/var/log/pki/pki-tomcat/ca/systemz'/var/log/pki/pki-tomcat/ca/transactionsz(/var/log/pki/pki-tomcat/ca/selftests.logz"/var/log/pki/pki-tomcat/catalina.*ú/var/log/pki/pki-ca-spawn.*z"/var/log/pki/pki-tomcat/kra/debug*z"/var/log/pki/pki-tomcat/kra/systemz(/var/log/pki/pki-tomcat/kra/transactionsz/var/log/pki/pki-kra-spawn.*r   )z/var/log/pki-ca/debugz/var/log/pki-ca/systemz/var/log/pki-ca/transactionsz/var/log/pki-ca/selftests.logz/var/log/pki-ca/catalina.*r   )Úadd_copy_spec)r   Úipa_versionr   r   r   Úretrieve_pki_logs1   s
   ÿzIpa.retrieve_pki_logsc                 C   s@  d| _ d| _d| _d| _|  ¡ }|  ¡ r'|  d¡ |  d| ¡ |  g d¢¡ |  ¡ r5|  d¡ |  	|¡ |  g d	¢¡ |d
krI| j | _
| j| _n| j| _
| j| _|  d| j
 ¡ |  d| j ¡ |  dddddddddd| j
 d| j d| j g¡ |  g d¢¡ t| dgd}| jd|d tdƒD ]	}|  d| ¡ q”d S ) Nz/var/lib/pki/pki-tomcatz/var/lib/pki-caz/etc/pki/pki-tomcat/caz/etc/pki-cazIPA server install detectedzIPA version is [%s])z/var/log/ipaserver-install.logz"/var/log/ipaserver-kra-install.logz/var/log/ipareplica-install.logz"/var/log/ipareplica-ca-install.logz/var/log/ipa-custodia.audit.logz$CA is installed: retrieving PKI logs)z/var/log/ipaclient-install.logz/var/log/ipaupgrade.logz/var/log/krb5kdc.logz#/var/log/dirsrv/slapd-*/logs/accessz#/var/log/dirsrv/slapd-*/logs/errorsz/etc/dirsrv/slapd-*/dse.ldifz&/etc/dirsrv/slapd-*/schema/99user.ldifz
/etc/hostsz/etc/httpd/alias/*z/etc/named.*z/etc/ipa/ca.crtz/etc/ipa/default.confz/etc/ipa/kdcproxy/kdcproxy.confz$/etc/ipa/kdcproxy/ipa-kdc-proxy.confz/etc/ipa/kdcproxy.confz/root/.ipa/log/cli.logú#/var/lib/certmonger/requests/[0-9]*z/var/lib/certmonger/cas/[0-9]*z/var/lib/ipa/ra-agent.pemz/var/lib/ipa/certs/httpd.crtz/var/kerberos/krb5kdc/kdc.crtz(/var/lib/ipa/sysrestore/sysrestore.statez)/var/log/ipa/healthcheck/healthcheck.log*r
   zcertutil -L -d %s/aliasz	%s/CS.cfgz/etc/pki/nssdb/key*z/etc/dirsrv/slapd-*/key*z/etc/dirsrv/slapd-*/pin.txtz/etc/dirsrv/slapd-*/pwdfile.txtz/etc/httpd/alias/ipasession.keyz/etc/httpd/alias/key*z/etc/httpd/alias/pin.txtz/etc/httpd/alias/pwdfile.txtz/etc/named.keytabz%s/alias/key*z%s/flatfile.txtz%s/password.conf)z"ls -la /etc/dirsrv/slapd-*/schema/z certutil -L -d /etc/httpd/alias/zpki-server cert-find --show-allz%pki-server subsystem-cert-validate caz klist -ket /etc/dirsrv/ds.keytabz%klist -ket /etc/httpd/conf/ipa.keytabz,klist -ket /var/lib/ipa/gssproxy/http.keytabZ
certmonger)Úservicesúgetcert list)Zpredz/etc/dirsrv/slapd-*/zcertutil -L -d %s)r   r   Zpki_tomcat_conf_dir_v4Zpki_tomcat_conf_dir_v3r   r   Z
_log_debugr   r   r   Zpki_tomcat_dirZpki_tomcat_conf_dirZadd_cmd_outputZadd_forbidden_pathr   r   )r   r   Zgetcert_predZcertdb_directoryr   r   r   ÚsetupI   sT   



ô
ÿz	Ipa.setupc                 C   sH   d}d}|   d||¡ |  ddd¡ d}t|ƒD ]	}|   |dd	¡ qd S )
Nz(\s*arg \"password )[^\"]*z
\1********z/etc/named.confr   z(pin=)'(\d+)'z\1'***'r   z(key_pin=)(\d+)z\1***)Zdo_file_subZdo_cmd_output_subr   )r   ÚmatchÚsubstZrequest_logsZrequest_logr   r   r   Úpostproc«   s   þþÿzIpa.postprocN)Ú__name__Ú
__module__Ú__qualname__Z
short_descZplugin_nameZprofilesZ
ipa_serverZ
ipa_clientÚfilesZpackagesr   r   r   r   r   r!   r   r   r   r   r      s    
br   N)Zsos.report.pluginsr   r   r   r   r   r   r   r   r   Ú<module>   s   
