__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
#!/usr/bin/python3 """Receive details from ApportUncaughtExceptionHandler. This generates and saves a problem report. """ # Copyright 2010 Canonical Ltd. # Author: Matt Zimmerman <[email protected]> # # 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. See http://www.gnu.org/copyleft/gpl.html for # the full text of the license. import os import sys import urllib.parse import apport.report from apport.packaging_impl import impl as packaging def make_title(report): """Construct crash title from stack trace.""" lines = report["StackTrace"].split("\n") message = lines[0].strip() stackframe = lines[1].strip() return f"{message} in {stackframe}" # pylint: disable-next=missing-function-docstring def main() -> int: if not packaging.enabled(): return 1 # read from the JVM process a sequence of key, value delimited by null # bytes items = sys.stdin.read().split("\0") data = {} while items: key = items.pop(0) if not items: break value = items.pop(0) data[key] = value # create report report = apport.report.Report(problem_type="Crash") # assume our parent is the JVM process report.pid = os.getppid() report.add_os_info() report.add_proc_info() # these aren't relevant because the crash was in bytecode del report["ProcMaps"] del report["ProcStatus"] report.add_user_info() # add in data which was fed to us from the JVM process for key, value in data.items(): report[key] = value # Add an ExecutablePath pointing to the file where the main class resides if "MainClassUrl" in report: url = report["MainClassUrl"] url_parts = urllib.parse.urlparse(url) path = url_parts.path if url_parts.scheme == "jar": # path is then a URL to the jar file url_parts = urllib.parse.urlparse(path) path = url_parts.path.split("!/", 1)[0] if url_parts.scheme == "file": report["ExecutablePath"] = path else: # Program at some non-file URL crashed. Give up. return 1 report["Title"] = make_title(report) try: with apport.fileutils.make_report_file(report) as report_file: report.write(report_file) except OSError as error: apport.fatal("Cannot create report: %s", str(error)) return 0 if __name__ == "__main__": sys.exit(main())
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| general-hooks | Folder | 0755 |
|
|
| package-hooks | Folder | 0755 |
|
|
| symptoms | Folder | 0755 |
|
|
| testsuite | Folder | 0755 |
|
|
| apport | File | 43.83 KB | 0755 |
|
| apport-checkreports | File | 1.37 KB | 0755 |
|
| apport-gtk | File | 24.34 KB | 0755 |
|
| apport-gtk.ui | File | 27.69 KB | 0644 |
|
| apport.jar | File | 2.38 KB | 0644 |
|
| apportcheckresume | File | 3.67 KB | 0755 |
|
| dump_acpi_tables.py | File | 1.72 KB | 0755 |
|
| gcc_ice_hook | File | 1.21 KB | 0755 |
|
| is-enabled | File | 672 B | 0755 |
|
| iwlwifi_error_dump | File | 2.25 KB | 0755 |
|
| java_uncaught_exception | File | 2.59 KB | 0755 |
|
| kernel_crashdump | File | 3.06 KB | 0755 |
|
| kernel_oops | File | 1.25 KB | 0755 |
|
| package_hook | File | 2.86 KB | 0755 |
|
| recoverable_problem | File | 2.41 KB | 0755 |
|
| root_info_wrapper | File | 96 B | 0755 |
|
| unkillable_shutdown | File | 3.63 KB | 0755 |
|
| whoopsie-upload-all | File | 8.33 KB | 0755 |
|