golden hour
/usr/lib/python3/dist-packages/DistUpgrade
⬆️ Go Up
Upload
File/Folder
Size
Actions
DistUpgradeApport.py
4.95 KB
Del
OK
DistUpgradeAptCdrom.py
12.39 KB
Del
OK
DistUpgradeCache.py
52.93 KB
Del
OK
DistUpgradeConfigParser.py
3.75 KB
Del
OK
DistUpgradeController.py
101.89 KB
Del
OK
DistUpgradeFetcher.py
5.87 KB
Del
OK
DistUpgradeFetcherCore.py
11.2 KB
Del
OK
DistUpgradeFetcherKDE.py
9.72 KB
Del
OK
DistUpgradeFetcherSelf.py
2.02 KB
Del
OK
DistUpgradeGettext.py
2.97 KB
Del
OK
DistUpgradeMain.py
9.1 KB
Del
OK
DistUpgradePatcher.py
3.92 KB
Del
OK
DistUpgradeQuirks.py
49.04 KB
Del
OK
DistUpgradeVersion.py
21 B
Del
OK
DistUpgradeView.py
16.43 KB
Del
OK
DistUpgradeViewGtk3.py
33.85 KB
Del
OK
DistUpgradeViewKDE.py
42.11 KB
Del
OK
DistUpgradeViewNonInteractive.py
13.54 KB
Del
OK
DistUpgradeViewText.py
12.53 KB
Del
OK
GtkProgress.py
3.93 KB
Del
OK
MetaRelease.py
17.06 KB
Del
OK
QUrlOpener.py
3.24 KB
Del
OK
ReleaseNotesViewer.py
7.48 KB
Del
OK
ReleaseNotesViewerWebkit.py
2.91 KB
Del
OK
SimpleGtk3builderApp.py
2.01 KB
Del
OK
SimpleGtkbuilderApp.py
1.99 KB
Del
OK
__init__.py
0 B
Del
OK
__pycache__
-
Del
OK
apt_btrfs_snapshot.py
9.64 KB
Del
OK
apt_clone.py
32.81 KB
Del
OK
dist-upgrade.py
129 B
Del
OK
distro.py
23.15 KB
Del
OK
telemetry.py
3.4 KB
Del
OK
utils.py
17.92 KB
Del
OK
xorg_fix_proprietary.py
3.99 KB
Del
OK
Edit: DistUpgradeApport.py
import os import logging import subprocess import sys import gettext import errno APPORT_WHITELIST = { "apt.log": "Aptlog", "apt-term.log": "Apttermlog", "apt-clone_system_state.tar.gz": "Aptclonesystemstate.tar.gz", "history.log": "Historylog", "lspci.txt": "Lspcitxt", "main.log": "Mainlog", "term.log": "Termlog", "screenlog.0": "Screenlog", "xorg_fixup.log": "Xorgfixup", } def _apport_append_logfiles(report, logdir="/var/log/dist-upgrade/"): dirname = 'VarLogDistupgrade' for fname in APPORT_WHITELIST: f = os.path.join(logdir, fname) if not os.path.isfile(f) or os.path.getsize(f) == 0: continue ident = dirname + APPORT_WHITELIST[fname] if os.access(f, os.R_OK): report[ident] = (open(f), ) elif os.path.exists(f): try: from apport.hookutils import root_command_output report[ident] = root_command_output( ["cat", '%s' % f], decode_utf8=False) except ImportError: logging.error("failed to import apport python module, " "can't include: %s" % ident) def apport_crash(type, value, tb): logging.debug("running apport_crash()") if "RELEASE_UPRADER_NO_APPORT" in os.environ: logging.debug("RELEASE_UPRADER_NO_APPORT env set") return False try: # we don't depend on python3-apport because of servers from apport_python_hook import apport_excepthook from apport.report import Report except ImportError as e: logging.error("failed to import apport python module, can't " "generate crash: %s" % e) return False from .DistUpgradeVersion import VERSION # we pretend we are do-release-upgrade sys.argv[0] = "/usr/bin/do-release-upgrade" apport_excepthook(type, value, tb) # now add the files in /var/log/dist-upgrade/* if os.path.exists('/var/crash/_usr_bin_do-release-upgrade.0.crash'): report = Report() report.setdefault('Tags', 'dist-upgrade') release = 'Ubuntu %s' % VERSION[0:5] report.setdefault('DistroRelease', release) # use the version of the release-upgrader tarball, not the installed # package report.setdefault('Package', 'ubuntu-release-upgrader-core 1:%s' % VERSION) _apport_append_logfiles(report) report.add_to_existing( '/var/crash/_usr_bin_do-release-upgrade.0.crash') return True def apport_pkgfailure(pkg, errormsg): logging.debug("running apport_pkgfailure() %s: %s", pkg, errormsg) if "RELEASE_UPRADER_NO_APPORT" in os.environ: logging.debug("RELEASE_UPRADER_NO_APPORT env set") return False LOGDIR = "/var/log/dist-upgrade/" s = "/usr/share/apport/package_hook" # we do not report followup errors from earlier failures # dpkg messages will not be translated if DPKG_UNTRANSLATED_MESSAGES is # set which it is by default so check for the English message first if "dependency problems - leaving unconfigured" in errormsg: logging.debug("dpkg error because of dependency problems, not " "reporting against %s " % pkg) return False needle = gettext.dgettext( 'dpkg', "dependency problems - leaving unconfigured") if needle in errormsg: logging.debug("dpkg error because of dependency problems, not " "reporting against %s " % pkg) return False # we do not run apport_pkgfailure for full disk errors if os.strerror(errno.ENOSPC) in errormsg: logging.debug("dpkg error because of full disk, not reporting " "against %s " % pkg) return False if os.path.exists(s): args = [s, "-p", pkg] args.extend(["--tags", "dist-upgrade"]) for fname in APPORT_WHITELIST: args.extend(["-l", os.path.join(LOGDIR, fname)]) try: p = subprocess.Popen(args, stdin=subprocess.PIPE, universal_newlines=True) p.stdin.write(errormsg) p.stdin.close() #p.wait() except Exception as e: logging.warning("Failed to run apport (%s)" % e) return False return True return False def run_apport(): " run apport, check if we have a display " if "RELEASE_UPRADER_NO_APPORT" in os.environ: logging.debug("RELEASE_UPRADER_NO_APPORT env set") return False if "DISPLAY" in os.environ: # update-notifier will notify about the crash return True elif os.path.exists("/usr/bin/apport-cli"): try: return (subprocess.call("/usr/bin/apport-cli") == 0) except Exception: logging.exception("Unable to launch '/usr/bin/apport-cli'") return False logging.debug("can't find apport") return False if __name__ == "__main__": apport_crash(None, None, None)
Save