Mister Spy Say ="Hello Kids ... :D" ___ ____ _ _____ | \/ (_) | | / ___| | . . |_ ___| |_ ___ _ __ \ `--. _ __ _ _ | |\/| | / __| __/ _ \ '__| `--. \ '_ \| | | | | | | | \__ \ || __/ | /\__/ / |_) | |_| | \_| |_/_|___/\__\___|_| \____/| .__/ \__, | | | __/ | |_| |___/ Bot Mister Spy V3
Mister Spy

Mister Spy

Current Path : /lib/python3.9/site-packages/sos/report/plugins/
Upload File :
Current File : //lib/python3.9/site-packages/sos/report/plugins/rabbitmq.py

# This file is part of the sos project: https://github.com/sosreport/sos
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# version 2 of the GNU General Public License.
#
# See the LICENSE file in the source distribution for further information.

from sos.report.plugins import Plugin, IndependentPlugin


class RabbitMQ(Plugin, IndependentPlugin):

    short_desc = 'RabbitMQ messaging service'
    plugin_name = 'rabbitmq'
    profiles = ('services',)
    var_puppet_gen = "/var/lib/config-data/puppet-generated/rabbitmq"
    files = (
        '/etc/rabbitmq/rabbitmq.conf',
        var_puppet_gen + '/etc/rabbitmq/rabbitmq.config'
    )
    packages = ('rabbitmq-server',)

    def setup(self):
        in_container = False
        container_names = []
        _containers = self.get_containers()
        for _con in _containers:
            if _con[1].startswith('rabbitmq'):
                in_container = True
                container_names.append(_con[1])

        if in_container:
            for container in container_names:
                self.add_container_logs(container)
                self.add_cmd_output(
                    'rabbitmqctl report',
                    container=container,
                    foreground=True,
                    tags="rabbitmq_report"
                )
                self.add_cmd_output(
                    "rabbitmqctl eval 'rabbit_diagnostics:maybe_stuck().'",
                    container=container,
                    foreground=True,
                    timeout=10
                )
        else:
            self.add_cmd_output("rabbitmqctl report")
            self.add_cmd_output(
                "rabbitmqctl eval 'rabbit_diagnostics:maybe_stuck().'",
                timeout=10)

        self.add_copy_spec([
            "/etc/rabbitmq/*",
            self.var_puppet_gen + "/etc/rabbitmq/*",
            self.var_puppet_gen + "/etc/security/limits.d/",
            self.var_puppet_gen + "/etc/systemd/"
        ])
        self.add_copy_spec([
            "/var/log/rabbitmq/*",
        ])

        self.add_file_tags({
            "/var/log/rabbitmq/rabbit@.*[^-sasl].log": "rabbitmq_logs",
            "/var/log/rabbitmq/startup_err": "rabbitmq_startup_err"
        })

        # Crash dump can be large in some situation but it is useful to
        # investigate why rabbitmq crashes. So capture the file without
        # sizelimit
        self.add_copy_spec([
            "/var/log/containers/rabbitmq/erl_crash.dump"
        ], sizelimit=0)

    def postproc(self):
        self.do_file_sub("/etc/rabbitmq/rabbitmq.conf",
                         r"(\s*default_pass\s*,\s*)\S+", r"\1<<***>>},")

# vim: set et ts=4 sw=4 :

Mr. DellatioNx196 GaLers xh3LL Backd00r 1.0, Coded By Mr. DellatioNx196 - Bogor BlackHat