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
123
124
125
|
### 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.
import os
from sos.plugins import Plugin, RedHatPlugin, UbuntuPlugin, DebianPlugin
class general(Plugin):
"""basic system information"""
plugin_name = "general"
optionList = [("syslogsize", "max size (MiB) to collect per syslog file", "", 15),
("all_logs", "collect all log files defined in syslog.conf", "", False)]
def setup(self):
self.add_copy_specs([
"/etc/init", # upstart
"/etc/event.d", # "
"/etc/inittab",
"/etc/sos.conf",
"/etc/sysconfig",
"/proc/stat",
"/var/log/dmesg",
"/var/log/sa",
"/var/log/pm/suspend.log",
"/var/log/up2date",
"/etc/hostid",
"/var/lib/dbus/machine-id",
"/etc/exports",
"/etc/localtime",
"/root/anaconda-ks.cfg"])
limit = self.get_option("syslogsize")
self.add_cmd_output("/bin/dmesg", suggest_filename="dmesg_now")
self.add_copy_spec_limit("/var/log/messages*", sizelimit = limit)
self.add_copy_spec_limit("/var/log/secure*", sizelimit = limit)
self.add_cmd_output("/usr/bin/hostid")
self.add_cmd_output("/bin/hostname", root_symlink="hostname")
self.add_cmd_output("/bin/date", root_symlink="date")
self.add_cmd_output("/usr/bin/uptime", root_symlink="uptime")
self.add_cmd_output("/bin/dmesg")
self.add_cmd_output("/usr/sbin/alternatives --display java",
root_symlink="java")
self.add_cmd_output("/usr/bin/readlink -f /usr/bin/java")
self.add_cmd_output("/usr/bin/tree /var/lib")
self.add_cmd_output("/bin/ls -lR /var/lib")
class RedHatGeneral(general, RedHatPlugin):
"""Basic system information for RedHat based distributions"""
def setup(self):
super(RedHatGeneral, self).setup()
self.add_copy_specs([
"/etc/redhat-release",
"/etc/fedora-release",
])
if self.get_option('all_logs'):
print "doing all_logs..."
limit = self.option_enabled("syslogsize")
logs = self.do_regex_find_all("^\S+\s+(-?\/.*$)\s+",
"/etc/syslog.conf")
print logs
if self.policy().pkgByName("rsyslog") \
or os.path.exists("/etc/rsyslog.conf"):
logs += self.do_regex_find_all("^\S+\s+(-?\/.*$)\s+", "/etc/rsyslog.conf")
print logs
for i in logs:
if i.startswith("-"):
i = i[1:]
if os.path.isfile(i):
self.add_copy_spec_limit(i, sizelimit = limit)
def postproc(self):
self.do_file_sub("/etc/sysconfig/rhn/up2date",
r"(\s*proxyPassword\s*=\s*)\S+", r"\1***")
class DebianGeneral(general, DebianPlugin, UbuntuPlugin):
"""Basic system information for Debian based distributions"""
def setup(self):
super(GeneralDebian, self).setup()
self.add_copy_specs([
"/etc/debian_version",
"/etc/default",
"/var/log/up2date",
"/etc/lsb-release"
])
class UbuntuGeneral(general, UbuntuPlugin):
"""Basic system information for Ubuntu based distributions"""
def setup(self):
super(GeneralUbuntu, self).setup()
self.add_copy_specs([
"/etc/os-release",
"/var/log/ufw.log",
"/var/log/apport.log",
"/var/log/syslog",
"/var/log/udev",
"/var/log/boot*",
"/var/log/dmesg*",
"/var/log/kern*",
"/var/log/mail*",
"/var/log/dist-upgrade",
"/var/log/landscape",
"/var/log/installer",
"/var/log/unattended-upgrades",
"/var/log/upstart"
])
self.add_cmd_output("/usr/sbin/ufw app list",root_symlink="ufw")
|