Apache/2.4.7 (Ubuntu) Linux sman1baleendah 3.13.0-24-generic #46-Ubuntu SMP Thu Apr 10 19:11:08 UTC 2014 x86_64 uid=33(www-data) gid=33(www-data) groups=33(www-data) safemode : OFF MySQL: ON | Perl: ON | cURL: OFF | WGet: ON > / usr / share / apport / package-hooks / | server ip : 104.21.89.46 your ip : 172.70.131.14 H O M E |
Filename | /usr/share/apport/package-hooks/source_apparmor.py |
Size | 2.25 kb |
Permission | rw-r--r-- |
Owner | root : root |
Create time | 27-Apr-2025 09:55 |
Last modified | 28-Mar-2014 00:03 |
Last accessed | 06-Jul-2025 16:31 |
Actions | edit | rename | delete | download (gzip) |
View | text | code | image |
'''apport package hook for apparmor
(c) 2009-2013 Canonical Ltd.
Author: Steve Beattie <[email protected]>
Jamie Strandboge <[email protected]>
License: GPLv2
'''
from apport.hookutils import *
import os
import re
def recent_kernlog(pattern):
'''Extract recent messages from kern.log or message which match a regex.
pattern should be a "re" object. '''
lines = ''
if os.path.exists('/var/log/kern.log'):
file = '/var/log/kern.log'
elif os.path.exists('/var/log/messages'):
file = '/var/log/messages'
else:
return lines
for line in open(file):
if pattern.search(line):
lines += line
return lines
def recent_syslog(pattern):
'''Extract recent messages from syslog which match a regex.
pattern should be a "re" object. '''
lines = ''
if os.path.exists('/var/log/syslog'):
file = '/var/log/syslog'
else:
return lines
for line in open(file):
if pattern.search(line):
lines += line
return lines
def add_info(report):
attach_file(report, '/proc/version_signature', 'ProcVersionSignature')
attach_file(report, '/proc/cmdline', 'ProcKernelCmdline')
sec_re = re.compile('audit\(|apparmor|selinux|security', re.IGNORECASE)
report['KernLog'] = recent_kernlog(sec_re)
# DBus messages are reported to syslog
dbus_sec_re = re.compile('dbus.* apparmor', re.IGNORECASE)
report['Syslog'] = recent_syslog(dbus_sec_re)
packages=['apparmor', 'apparmor-utils', 'libapparmor1',
'libapparmor-dev', 'libapparmor-perl', 'apparmor-utils',
'apparmor-docs', 'apparmor-profiles', 'libapache2-mod-apparmor',
'libpam-apparmor', 'auditd', 'libaudit0']
versions = ''
for package in packages:
try:
version = packaging.get_version(package)
except ValueError:
version = 'N/A'
if version is None:
version = 'N/A'
versions += '%s %s\n' % (package, version)
report['ApparmorPackages'] = versions
# These need to be run as root
report['ApparmorStatusOutput'] = root_command_output(['/usr/sbin/apparmor_status'])
report['PstreeP'] = command_output(['/usr/bin/pstree', '-p'])
attach_file_if_exists(report, '/var/log/audit/audit.log', 'audit.log')
(c) 2009-2013 Canonical Ltd.
Author: Steve Beattie <[email protected]>
Jamie Strandboge <[email protected]>
License: GPLv2
'''
from apport.hookutils import *
import os
import re
def recent_kernlog(pattern):
'''Extract recent messages from kern.log or message which match a regex.
pattern should be a "re" object. '''
lines = ''
if os.path.exists('/var/log/kern.log'):
file = '/var/log/kern.log'
elif os.path.exists('/var/log/messages'):
file = '/var/log/messages'
else:
return lines
for line in open(file):
if pattern.search(line):
lines += line
return lines
def recent_syslog(pattern):
'''Extract recent messages from syslog which match a regex.
pattern should be a "re" object. '''
lines = ''
if os.path.exists('/var/log/syslog'):
file = '/var/log/syslog'
else:
return lines
for line in open(file):
if pattern.search(line):
lines += line
return lines
def add_info(report):
attach_file(report, '/proc/version_signature', 'ProcVersionSignature')
attach_file(report, '/proc/cmdline', 'ProcKernelCmdline')
sec_re = re.compile('audit\(|apparmor|selinux|security', re.IGNORECASE)
report['KernLog'] = recent_kernlog(sec_re)
# DBus messages are reported to syslog
dbus_sec_re = re.compile('dbus.* apparmor', re.IGNORECASE)
report['Syslog'] = recent_syslog(dbus_sec_re)
packages=['apparmor', 'apparmor-utils', 'libapparmor1',
'libapparmor-dev', 'libapparmor-perl', 'apparmor-utils',
'apparmor-docs', 'apparmor-profiles', 'libapache2-mod-apparmor',
'libpam-apparmor', 'auditd', 'libaudit0']
versions = ''
for package in packages:
try:
version = packaging.get_version(package)
except ValueError:
version = 'N/A'
if version is None:
version = 'N/A'
versions += '%s %s\n' % (package, version)
report['ApparmorPackages'] = versions
# These need to be run as root
report['ApparmorStatusOutput'] = root_command_output(['/usr/sbin/apparmor_status'])
report['PstreeP'] = command_output(['/usr/bin/pstree', '-p'])
attach_file_if_exists(report, '/var/log/audit/audit.log', 'audit.log')