Linux webserver 6.8.0-49-generic #49~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Wed Nov 6 17:42:15 UTC 2 x86_64
Apache/2.4.52 (Ubuntu)
Server IP : 192.168.1.1 & Your IP : 18.191.150.27
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
lib /
python3 /
dist-packages /
DistUpgrade /
Delete
Unzip
Name
Size
Permission
Date
Action
__pycache__
[ DIR ]
drwxr-xr-x
2024-09-18 19:49
DistUpgradeApport.py
4.94
KB
-rw-r--r--
2023-04-03 14:58
DistUpgradeCache.py
52.95
KB
-rw-r--r--
2023-01-09 17:05
DistUpgradeConfigParser.py
3.75
KB
-rw-r--r--
2023-01-09 17:05
DistUpgradeController.py
98.91
KB
-rw-r--r--
2023-10-12 15:35
DistUpgradeFetcher.py
5.87
KB
-rw-r--r--
2023-01-09 17:05
DistUpgradeFetcherCore.py
12.45
KB
-rw-r--r--
2023-06-14 16:48
DistUpgradeFetcherKDE.py
9.72
KB
-rw-r--r--
2023-10-12 15:35
DistUpgradeFetcherSelf.py
1.91
KB
-rw-r--r--
2023-01-09 17:05
DistUpgradeGettext.py
2.97
KB
-rw-r--r--
2023-01-09 17:05
DistUpgradeMain.py
9.14
KB
-rw-r--r--
2023-01-09 17:05
DistUpgradePatcher.py
3.92
KB
-rw-r--r--
2023-01-09 17:05
DistUpgradeQuirks.py
68.71
KB
-rw-r--r--
2023-10-12 15:35
DistUpgradeVersion.py
21
B
-rw-r--r--
2024-09-10 12:28
DistUpgradeView.py
16.94
KB
-rw-r--r--
2023-04-03 14:58
DistUpgradeViewGtk3.py
33.86
KB
-rw-r--r--
2023-10-12 15:35
DistUpgradeViewKDE.py
40.87
KB
-rw-r--r--
2023-10-12 15:35
DistUpgradeViewNonInteractive.py
13.54
KB
-rw-r--r--
2023-04-03 15:20
DistUpgradeViewText.py
12.53
KB
-rw-r--r--
2023-01-09 17:05
GtkProgress.py
3.93
KB
-rw-r--r--
2023-01-09 17:05
MetaRelease.py
17.13
KB
-rw-r--r--
2024-06-26 09:01
QUrlOpener.py
3.24
KB
-rw-r--r--
2023-01-09 17:05
ReleaseNotesViewer.py
7.48
KB
-rw-r--r--
2023-01-09 17:05
ReleaseNotesViewerWebkit.py
2.91
KB
-rw-r--r--
2023-10-12 15:35
SimpleGtk3builderApp.py
2.01
KB
-rw-r--r--
2023-01-09 17:05
SimpleGtkbuilderApp.py
1.99
KB
-rw-r--r--
2023-01-09 17:05
__init__.py
0
B
-rw-r--r--
2022-02-02 15:00
apt_btrfs_snapshot.py
9.68
KB
-rw-r--r--
2024-09-10 12:28
apt_clone.py
32.74
KB
-rw-r--r--
2021-09-20 20:21
dist-upgrade.py
129
B
-rw-r--r--
2023-01-09 17:05
distro.py
23.21
KB
-rw-r--r--
2024-09-02 17:09
telemetry.py
3.4
KB
-rw-r--r--
2023-01-09 17:05
utils.py
18.11
KB
-rw-r--r--
2024-06-26 09:01
xorg_fix_proprietary.py
3.99
KB
-rw-r--r--
2023-01-09 17:05
Save
Rename
# DistUpgradeEdPatcher.py # # Copyright (c) 2011 Canonical # # Author: Michael Vogt <michael.vogt@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. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 # USA import hashlib import re class PatchError(Exception): """ Error during the patch process """ pass def patch(orig, edpatch, result_md5sum=None): """ python implementation of enough "ed" to apply ed-style patches. Note that this patches in memory so its *not* suitable for big files """ # we only have two states, waiting for command or reading data (STATE_EXPECT_COMMAND, STATE_EXPECT_DATA) = range(2) # this is inefficient for big files with open(orig, encoding="UTF-8") as f: orig_lines = f.readlines() start = end = 0 # we start in wait-for-commend state state = STATE_EXPECT_COMMAND with open(edpatch, encoding="UTF-8") as f: lines = f.readlines() for line in lines: if state == STATE_EXPECT_COMMAND: # in commands get rid of whitespace, line = line.strip() # check if we have a substitute command if line.startswith("s/"): # strip away the "s/" line = line[2:] # chop off the flags at the end subs, flags = line.rsplit("/", 1) if flags: raise PatchError("flags for s// not supported yet") # get the actual substitution regexp and replacement and # execute it regexp, sep, repl = subs.partition("/") new, count = re.subn(regexp, repl, orig_lines[start], count=1) orig_lines[start] = new continue # otherwise the last char is the command command = line[-1] # read address (start_str, sep, end_str) = line[:-1].partition(",") # ed starts with 1 while python with 0 start = int(start_str) start -= 1 # if we don't have end, set it to the next line if end_str == "": end = start + 1 else: end = int(end_str) # interpret command if command == "c": del orig_lines[start:end] state = STATE_EXPECT_DATA start -= 1 elif command == "a": # not allowed to have a range in append state = STATE_EXPECT_DATA elif command == "d": del orig_lines[start:end] else: raise PatchError("unknown command: '%s'" % line) elif state == STATE_EXPECT_DATA: # this is the data end marker if line == ".\n": state = STATE_EXPECT_COMMAND else: # copy line verbatim and increase position start += 1 orig_lines.insert(start, line) # done with the patching, (optional) verify and write result result = "".join(orig_lines) if result_md5sum: md5 = hashlib.md5() md5.update(result.encode("UTF-8")) if md5.hexdigest() != result_md5sum: raise PatchError("the md5sum after patching is not correct") with open(orig, "w", encoding="UTF-8") as f: f.write(result) return True