OXIESEC PANEL
- Current Dir:
/
/
snap
/
core
/
17200
/
usr
/
lib
/
python3
/
dist-packages
/
cloudinit
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
__init__.py
0 bytes
03/19/2021 02:37:22 PM
rw-r--r--
📁
__pycache__
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📁
analyze
-
02/18/2024 07:58:20 PM
rwxr-xr-x
📄
apport.py
4.08 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
atomic_helper.py
1.33 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
cloud.py
3.15 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
cmd
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📁
config
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
cs_utils.py
3 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
dhclient_hook.py
2.48 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
distros
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
dmi.py
5.63 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
ec2_utils.py
8.75 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
event.py
450 bytes
03/19/2021 02:37:22 PM
rw-r--r--
📄
features.py
2.03 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
filters
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
gpg.py
3.35 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
handlers
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
helpers.py
15.71 KB
04/25/2023 09:28:10 PM
rw-r--r--
📄
importer.py
1.38 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
log.py
4.33 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
mergers
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📁
net
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
netinfo.py
18.12 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
patcher.py
1.23 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
persistence.py
2.54 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
registry.py
1.01 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
reporting
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
safeyaml.py
1.19 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
serial.py
1.15 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
settings.py
1.89 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
signal_handler.py
1.8 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
simpletable.py
1.85 KB
03/19/2021 02:37:22 PM
rw-r--r--
📁
sources
-
02/18/2024 07:58:21 PM
rwxr-xr-x
📄
ssh_util.py
13.37 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
stages.py
38.67 KB
04/25/2023 09:28:10 PM
rw-r--r--
📄
subp.py
13.06 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
temp_utils.py
2.87 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
templater.py
6.4 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
type_utils.py
726 bytes
03/19/2021 02:37:22 PM
rw-r--r--
📄
url_helper.py
21.74 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
user_data.py
14.3 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
util.py
78.86 KB
03/19/2021 02:37:22 PM
rw-r--r--
📄
version.py
599 bytes
04/25/2023 09:28:48 PM
rw-r--r--
📄
warnings.py
3.83 KB
03/19/2021 02:37:22 PM
rw-r--r--
Editing: log.py
Close
# Copyright (C) 2012 Canonical Ltd. # Copyright (C) 2012 Hewlett-Packard Development Company, L.P. # Copyright (C) 2012 Yahoo! Inc. # # Author: Scott Moser <scott.moser@canonical.com> # Author: Juerg Haefliger <juerg.haefliger@hp.com> # Author: Joshua Harlow <harlowja@yahoo-inc.com> # # This file is part of cloud-init. See LICENSE file for license information. import collections import io import logging import logging.config import logging.handlers import os import sys import time # Logging levels for easy access CRITICAL = logging.CRITICAL FATAL = logging.FATAL ERROR = logging.ERROR WARNING = logging.WARNING WARN = logging.WARN INFO = logging.INFO DEBUG = logging.DEBUG NOTSET = logging.NOTSET # Default basic format DEF_CON_FORMAT = '%(asctime)s - %(filename)s[%(levelname)s]: %(message)s' # Always format logging timestamps as UTC time logging.Formatter.converter = time.gmtime def setupBasicLogging(level=DEBUG, formatter=None): if not formatter: formatter = logging.Formatter(DEF_CON_FORMAT) root = logging.getLogger() for handler in root.handlers: if hasattr(handler, 'stream') and hasattr(handler.stream, 'name'): if handler.stream.name == '<stderr>': handler.setLevel(level) return # Didn't have an existing stderr handler; create a new handler console = logging.StreamHandler(sys.stderr) console.setFormatter(formatter) console.setLevel(level) root.addHandler(console) root.setLevel(level) def flushLoggers(root): if not root: return for h in root.handlers: if isinstance(h, (logging.StreamHandler)): try: h.flush() except IOError: pass flushLoggers(root.parent) def setupLogging(cfg=None): # See if the config provides any logging conf... if not cfg: cfg = {} log_cfgs = [] log_cfg = cfg.get('logcfg') if log_cfg and isinstance(log_cfg, str): # If there is a 'logcfg' entry in the config, # respect it, it is the old keyname log_cfgs.append(str(log_cfg)) elif "log_cfgs" in cfg: for a_cfg in cfg['log_cfgs']: if isinstance(a_cfg, str): log_cfgs.append(a_cfg) elif isinstance(a_cfg, (collections.Iterable)): cfg_str = [str(c) for c in a_cfg] log_cfgs.append('\n'.join(cfg_str)) else: log_cfgs.append(str(a_cfg)) # See if any of them actually load... am_tried = 0 for log_cfg in log_cfgs: try: am_tried += 1 # Assume its just a string if not a filename if log_cfg.startswith("/") and os.path.isfile(log_cfg): # Leave it as a file and do not make it look like # something that is a file (but is really a buffer that # is acting as a file) pass else: log_cfg = io.StringIO(log_cfg) # Attempt to load its config logging.config.fileConfig(log_cfg) # The first one to work wins! return except Exception: # We do not write any logs of this here, because the default # configuration includes an attempt at using /dev/log, followed # up by writing to a file. /dev/log will not exist in very early # boot, so an exception on that is expected. pass # If it didn't work, at least setup a basic logger (if desired) basic_enabled = cfg.get('log_basic', True) sys.stderr.write(("WARN: no logging configured!" " (tried %s configs)\n") % (am_tried)) if basic_enabled: sys.stderr.write("Setting up basic logging...\n") setupBasicLogging() def getLogger(name='cloudinit'): return logging.getLogger(name) def _resetLogger(log): """Remove all current handlers, unset log level and add a NullHandler. (Adding the NullHandler avoids "No handlers could be found for logger XXX" messages.) """ if not log: return handlers = list(log.handlers) for h in handlers: h.flush() h.close() log.removeHandler(h) log.setLevel(NOTSET) log.addHandler(logging.NullHandler()) def resetLogging(): _resetLogger(logging.getLogger()) _resetLogger(getLogger()) resetLogging() # vi: ts=4 expandtab