summaryrefslogtreecommitdiffstats
path: root/remote/modules/debug/data/opt/openslx/bin/debug_report
blob: 4cdfae4e1c4a51d69d51e8d49d0c99f6936a7bf3 (plain) (blame)
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
#!/bin/ash

TOOLS="
	journalctl
	systemctl
	loginctl
	lspci
	lsusb
	lsmod
	mount
"

URL="http://132.230.8.113/error_report.php"

if [ "$UID" != "0" ]; then
	echo "Debug Reports können nur von root versendet werden" >&2
	exit 1
fi

if ! curl -H "Expect:" -f -s -S --connect-timeout 5 "$URL" > /dev/null; then
	echo "Kann den Debug-Report-Server in Freiburg nicht erreichen. :-(" >&2
	exit 1
fi

rm -rf /tmp/debug-report
mkdir -p /tmp/debug-report/{static,generated}

if [ ! -d /tmp/debug-report ]; then
	echo "FEHLER: Konnte /tmp/debug-report nicht erstellen!" >&2
	exit 1
fi

cd /tmp/debug-report

cat > err-desc <<HEREEND

# Bitte hier kurz eine passende Fehlerbeschreibung eingeben, anschließend
# Strg+O, ENTER, und Strg+X drücken.
HEREEND

nano -w err-desc

echo -n "Beginne mit dem Erstellen des Fehlerberichts..."

. /opt/openslx/config

echo "TIME INFORMATION:" > metadata
hwclock >> metadata
date >> metadata
for srv in 132.230.1.9 $SLX_NTP_SERVER 0.de.pool.ntp.org; do
	ntpdate -u -q -p 2 -t 1 "$srv" >> metadata && break
done
echo -n "..."

cp /opt/openslx/config /tmp/udhcpclog static/ 2> /dev/null
echo -n "."

find /tmp/vmware* -name "*.log" -exec cp {} static/ \; 2> /dev/null
echo -n "."

cp /var/log/Xorg.0.lo* static/ 2> /dev/null
cp /var/log/{auth.log,kdm.log,syslog,messages,user.log} static/ 2> /dev/null
cp /proc/cpuinfo static/ 2> /dev/null
echo -n "."

for tool in $TOOLS; do
	$tool > "generated/${tool}-out" 2> "generated/${tool}-err"
	echo -n "."
done

ip a > "generated/ip-a-out" 2> "generated/ip-a-err"
echo -n "."

systemctl status > "generated/systemctl-status-out" 2> "generated/systemctl-status-err"
echo -n "."

ps aux > "generated/ps-out" 2> "generated/ps-err"
echo -n "."

echo "..fertig!"

cd /tmp
rm -f error-report.tar.gz
echo -n "Packe Fehlerbericht ein..."
if ! tar czf error-report.tar.gz debug-report; then
	echo "Fehler beim Packen des Berichts!" >&2
	exit 1
fi
echo "....fertig!"

echo -n "Lade Fehlerbericht hoch...."
if ! curl -H "Expect:" -f -s -S -F "file=@error-report.tar.gz;filename=report" "$URL" > /dev/null; then
	echo "Fehler beim Hochladen des Fehlerberichts :-(" >&2
	exit 1
fi

echo "Fehlerbericht erfolgreich versendet!"