D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
lib
/
python2.7
/
site-packages
/
sos
/
plugins
/
Filename :
openstack_placement.py
back
Copy
# Copyright (C) 2019 Red Hat, Inc., Lee Yarwood <lyarwood@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. from sos.plugins import Plugin, RedHatPlugin, DebianPlugin, UbuntuPlugin class OpenStackPlacement(Plugin): """OpenStack Placement """ plugin_name = "openstack_placement" profiles = ('openstack', 'openstack_controller') var_puppet_gen = "/var/lib/config-data/puppet-generated/placement" def setup(self): # collect commands output only if the openstack-placement-api service # is running in_container = self.running_in_container() if self.is_service_running('openstack-placement-api') or in_container: placement_config = "" # if containerized we need to pass the config to the cont. if in_container: placement_config = "--config-dir " + self.var_puppet_gen + \ "/etc/placement/" self.add_cmd_output( "placement-manage " + placement_config + " db version", suggest_filename="placement-manage_db_version" ) if self.get_option("all_logs"): self.add_copy_spec([ "/var/log/placement/", "/var/log/containers/placement/", "/var/log/containers/httpd/placement-api/" ]) else: self.add_copy_spec([ "/var/log/placement/*.log", "/var/log/containers/placement/*.log", "/var/log/containers/httpd/placement-api/*log", ]) self.add_copy_spec([ "/etc/placement/", self.var_puppet_gen + "/etc/placement/", self.var_puppet_gen + "/etc/my.cnf.d/tripleo.cnf", self.var_puppet_gen + "/etc/httpd/conf/", self.var_puppet_gen + "/etc/httpd/conf.d/", self.var_puppet_gen + "/etc/httpd/conf.modules.d/*.conf", ]) def running_in_container(self): for runtime in ["docker", "podman"]: container_status = self.exec_cmd(runtime + " ps") if container_status['status'] == 0: for line in container_status['output'].splitlines(): if line.endswith("placement_api"): return True return False def apply_regex_sub(self, regexp, subst): self.do_path_regex_sub("/etc/placement/*", regexp, subst) self.do_path_regex_sub( self.var_puppet_gen + "/etc/placement/*", regexp, subst ) def postproc(self): protect_keys = ["password"] connection_keys = ["database_connection", "slave_connection"] self.apply_regex_sub( r"((?m)^\s*(%s)\s*=\s*)(.*)" % "|".join(protect_keys), r"\1*********" ) self.apply_regex_sub( r"((?m)^\s*(%s)\s*=\s*(.*)://(\w*):)(.*)(@(.*))" % "|".join(connection_keys), r"\1*********\6" ) class DebianPlacement(OpenStackPlacement, DebianPlugin, UbuntuPlugin): packages = ('placement') def setup(self): super(DebianPlacement, self).setup() class RedHatPlacement(OpenStackPlacement, RedHatPlugin): packages = ('openstack-selinux') def setup(self): super(RedHatPlacement, self).setup() if self.get_option("all_logs"): self.add_copy_spec("/var/log/httpd/placement*") else: self.add_copy_spec("/var/log/httpd/placement*.log") # vim: set et ts=4 sw=4 :