403Webshell
Server IP : 15.235.198.142  /  Your IP : 216.73.216.14
Web Server : Apache/2.4.58 (Ubuntu)
System : Linux ballsack 6.8.0-45-generic #45-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 30 12:02:04 UTC 2024 x86_64
User : www-data ( 33)
PHP Version : 8.3.6
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : OFF  |  Sudo : ON  |  Pkexec : OFF
Directory :  /proc/self/root/usr/share/apport/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /proc/self/root/usr/share/apport/java_uncaught_exception
#!/usr/bin/python3

"""Receive details from ApportUncaughtExceptionHandler.

This generates and saves a problem report.
"""

# Copyright 2010 Canonical Ltd.
# Author: Matt Zimmerman <mdz@ubuntu.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.  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():
    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())

Youez - 2016 - github.com/yon3zu
LinuXploit