AnonSec Shell
Server IP : 92.204.138.22  /  Your IP : 3.21.93.81
Web Server : Apache
System : Linux ns1009439.ip-92-204-138.us 4.18.0-553.8.1.el8_10.x86_64 #1 SMP Tue Jul 2 07:26:33 EDT 2024 x86_64
User : internationaljou ( 1019)
PHP Version : 7.4.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : ON  |  Pkexec : ON
Directory :  /lib/python3.6/site-packages/sos/report/plugins/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     

Current File : /lib/python3.6/site-packages/sos/report/plugins/openstack_gnocchi.py
# Copyright (C) 2016 Red Hat, Inc., Sachin Patil <psachin@redhat.com>
# Copyright (C) 2017 Red Hat, Inc., Martin Schuppert <mschuppert@redhat.com>

# 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.

import os
from sos.report.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin


class Gnocchi(Plugin):

    short_desc = 'Gnocchi - Metric as a service'
    plugin_name = "openstack_gnocchi"

    profiles = ('openstack', 'openstack_controller')
    apachepkg = None

    def setup(self):
        self.add_copy_spec([
            "/etc/gnocchi/*",
        ])

        if self.get_option("all_logs"):
            self.add_copy_spec([
                "/var/log/gnocchi/*",
                f"/var/log/{self.apachepkg}*/gnocchi*"
            ])
        else:
            self.add_copy_spec([
                "/var/log/gnocchi/*.log",
                f"/var/log/{self.apachepkg}*/gnocchi*.log"
            ])

        vars_all = [p in os.environ for p in [
                    'OS_USERNAME', 'OS_PASSWORD']]

        vars_any = [p in os.environ for p in [
                    'OS_TENANT_NAME', 'OS_PROJECT_NAME']]

        if not (all(vars_all) and any(vars_any)):
            self.soslog.warning("Not all environment variables set. Source "
                                "the environment file for the user intended "
                                "to connect to the OpenStack environment.")
        else:
            self.add_cmd_output([
                "gnocchi --version",
                "gnocchi status",
                "gnocchi capabilities list",
                "gnocchi archive-policy list",
                "gnocchi resource list",
                "gnocchi resource-type list"
            ])

    def postproc(self):
        self.do_file_sub(
            "/etc/gnocchi/gnocchi.conf",
            r"(ceph_secret|password|memcache_secret_key)\s?=(.*)",
            r"\1=*****",
        )


class RedHatGnocchi(Gnocchi, RedHatPlugin):

    apachepkg = 'httpd'
    var_puppet_gen = "/var/lib/config-data/puppet-generated/gnocchi"

    packages = (
        'openstack-gnocchi-metricd', 'openstack-gnocchi-common',
        'openstack-gnocchi-statsd', 'openstack-gnocchi-api',
        'openstack-gnocchi-carbonara'
    )

    def setup(self):
        super().setup()
        self.add_copy_spec([
            self.var_puppet_gen + "/etc/gnocchi/*",
            self.var_puppet_gen + "/etc/httpd/conf/*",
            self.var_puppet_gen + "/etc/httpd/conf.d/*",
            self.var_puppet_gen + "/etc/httpd/conf.modules.d/wsgi.conf",
            self.var_puppet_gen + "/etc/my.cnf.d/tripleo.cnf"
        ])

    def postproc(self):
        super().postproc()
        self.do_file_sub(
            self.var_puppet_gen + "/etc/gnocchi/"
            "gnocchi.conf",
            r"(ceph_secret|password|memcache_secret_key)\s?=(.*)",
            r"\1=*****",
        )


class DebianGnocchi(Gnocchi, DebianPlugin, UbuntuPlugin):

    apachepkg = 'apache2'

    packages = (
        'gnocchi-api',
        'gnocchi-metricd',
        'gnocchi-common',
        'gnocchi-statsd',
        'python-gnocchi',
        'python3-gnocchi',
    )

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

Anon7 - 2022
AnonSec Team