a >hY@s>ddlmZddlmZddlmZmZGdddeeZdS))match)quote)Plugin RedHatPluginc@s>eZdZdZdZdZdZdZdZddZ d dd Z d d Z dS) Candlepinz Candlepin entitlement management candlepin)rNc CsVd|_d|_d}zt|ddd}|}Wdn1sB0Y|D]f}|rP|ddkrfqPtd |r|d d |_|jd d dd|_td|rP|d d |_qPWnttfyYn0| ddddd|ji|_ |j ddgdd| gd| d| d}|j |d|j d| d}|j |d|j ddS)NZ localhost/etc/candlepin/candlepin.confrzUTF--8)encodingr#z&^\s*org.quartz.dataSource.myDS.URL=\S+=/:z+^\s*org.quartz.dataSource.myDS.password=\S+Z candlepin_logZcandlepin_error_logZcandlepin_conf)z"/var/log/candlepin/candlepin.log.*z/var/log/candlepin/err.log.*r Z PGPASSWORDz/var/log/candlepin/error.logz /var/log/candlepin/candlepin.log)Z sizelimit) r /etc/candlepin/broker.xmlz/var/log/candlepin/audit*.log*z%/var/log/candlepin/candlepin.log[.-]*z/var/log/candlepin/cpdb*.log*z/var/log/candlepin/cpinit*.log*z!/var/log/candlepin/error.log[.-]*z/var/log/tomcat*/catalina*log*z"/var/log/tomcat*/host-manager*log*z/var/log/tomcat*/localhost*log*z/var/log/tomcat*/manager*log*zdu -sh /var/lib/candlepin/*/*a[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 DESCZcandlepin_db_tables_sizes)Zsuggest_filenameenvzN SELECT displayname, content_access_mode FROM cp_owner;Zsimple_content_access)dbhostdbpasswdopenread splitlinesrsplitIOError IndexErrorZ add_file_tagsrZ add_copy_specZadd_cmd_outputbuild_query_cmd)selfZcfg_filecfileZ candle_lineslineZ_cmdr @/usr/lib/python3.9/site-packages/sos/report/plugins/candlepin.pysetupsR*     zCandlepin.setupFcCs$|rdnd}d}||j|t|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 -A -F , -XrzUpsql --no-password -h %s -p 5432 -U candlepin -d candlepin %s -c %s)rr)rqueryZcsvZ csvformatZ_dbcmdr r r!rts zCandlepin.build_query_cmdcCsLd}d}|d||d}|d||dD]}|dd|d d q,dS) Nz$(((.*)(pass|token|secret)(.*))=)(.*)z \1********r z(--password=)([a-zA-Z0-9]*)z/var/log/candlepin/cpdb.log)ZtrustStorePasswordZkeyStorePasswordr(z )=(\w*)([;<])z \1=********\3)Z do_file_sub)rZregreplZcpdbregkeyr r r!postprocs zCandlepin.postproc)F) __name__ __module__ __qualname__Z short_descZ plugin_nameZpackagesrrrr"rr'r r r r!rsY rN)rerZshlexrZsos.report.pluginsrrrr r r r! s