1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
# Copyright (C) 2015 Red Hat, Inc., Lee Yarwood <lyarwood@redhat.com>
# Copyright (C) 2017 Red Hat, Inc., Martin Schuppert <mschuppert@redhat.com>
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
from sos.plugins import Plugin, RedHatPlugin
import os
class OpenStackInstack(Plugin):
"""OpenStack Instack
"""
plugin_name = "openstack_instack"
profiles = ('openstack', 'openstack_undercloud')
def setup(self):
self.add_copy_spec("/home/stack/.instack/install-undercloud.log")
self.add_copy_spec("/home/stack/instackenv.json")
self.add_copy_spec("/home/stack/undercloud.conf")
if self.get_option("verify"):
self.add_cmd_output("rpm -V %s" % ' '.join(packages))
self.limit = self.get_option("log_size")
if self.get_option("all_logs"):
self.add_copy_spec_limit("/var/log/mistral/",
sizelimit=self.limit)
self.add_copy_spec_limit("/var/log/zaqar/",
sizelimit=self.limit)
else:
self.add_copy_spec_limit("/var/log/mistral/*.log",
sizelimit=self.limit)
self.add_copy_spec_limit("/var/log/zaqar/*.log",
sizelimit=self.limit)
vars = [p in os.environ for p in [
'OS_USERNAME', 'OS_PASSWORD', 'OS_TENANT_NAME']]
if not all(vars):
self.soslog.warning("Not all environment variables set. Source "
"the environment file for the user intended "
"to connect to the OpenStack environment.")
else:
# get status of overcloud stack and resources
self.add_cmd_output("openstack stack show overcloud")
self.add_cmd_output(
"openstack stack resource list -n 10 overcloud",
timeout=600)
# get details on failed deployments
cmd = "openstack stack resource list -f value -n 5 overcloud"
deployments = self.call_ext_prog(cmd, timeout=600)['output']
for deployment in deployments.splitlines():
if 'FAILED' in deployment:
check = [
"OS::Heat::StructuredDeployment",
"OS::Heat::SoftwareDeployment"]
if any(x in deployment for x in check):
deployment = deployment.split()[1]
cmd = "openstack software deployment show " \
"--long %s" % (deployment)
self.add_cmd_output(
cmd,
suggest_filename="failed-deployment-" +
deployment + ".log",
timeout=600)
def postproc(self):
protected_keys = [
"UNDERCLOUD_TUSKAR_PASSWORD", "UNDERCLOUD_ADMIN_PASSWORD",
"UNDERCLOUD_CEILOMETER_METERING_SECRET",
"UNDERCLOUD_CEILOMETER_PASSWORD",
"UNDERCLOUD_CEILOMETER_SNMPD_PASSWORD",
"UNDERCLOUD_DB_PASSWORD", "UNDERCLOUD_GLANCE_PASSWORD",
"UNDERCLOUD_HEAT_PASSWORD",
"UNDERCLOUD_HEAT_STACK_DOMAIN_ADMIN_PASSWORD",
"UNDERCLOUD_HORIZON_SECRET_KEY", "UNDERCLOUD_IRONIC_PASSWORD",
"UNDERCLOUD_NEUTRON_PASSWORD", "UNDERCLOUD_NOVA_PASSWORD",
"UNDERCLOUD_RABBIT_PASSWORD", "UNDERCLOUD_SWIFT_PASSWORD",
"UNDERCLOUD_TUSKAR_PASSWORD", "OS_PASSWORD",
"undercloud_db_password", "undercloud_admin_password",
"undercloud_glance_password", "undercloud_heat_password",
"undercloud_neutron_password", "undercloud_nova_password",
"undercloud_ironic_password", "undercloud_tuskar_password",
"undercloud_ceilometer_password",
"undercloud_ceilometer_metering_secret",
"undercloud_ceilometer_snmpd_password",
"undercloud_swift_password", "undercloud_rabbit_password",
"undercloud_heat_stack_domain_admin_password"
]
regexp = r"((?m)(%s)=)(.*)" % "|".join(protected_keys)
self.do_file_sub("/home/stack/.instack/install-undercloud.log",
regexp, r"\1*********")
self.do_file_sub("/home/stack/undercloud.conf", regexp, r"\1*********")
protected_json_keys = ["pm_password", "ssh-key", "password"]
json_regexp = r'((?m)"(%s)": )(".*?")' % "|".join(protected_json_keys)
self.do_file_sub("/home/stack/instackenv.json", json_regexp,
r"\1*********")
class RedHatRDOManager(OpenStackInstack, RedHatPlugin):
packages = [
'instack',
'instack-undercloud',
]
def setup(self):
super(RedHatRDOManager, self).setup()
# vim: set et ts=4 sw=4 :
|