class StdoutLogger(object): def __init__(self, loglevel=LOG_DEBUG, servicename=__default_servicename__): self.loglevel = loglevel h = logging.StreamHandler() h.setLevel(loglevel) fmt = logging.Formatter("%(asctime)s " + servicename + "[%(process)d]: %(levelname)s: %(message)s") h.setFormatter(fmt) self._logger = RootLogger(loglevel) self._logger.addHandler(h) def set_debug(self): self.loglevel = LOG_DEBUG self._logger.setLevel(self.loglevel) def set_info(self): self.loglevel = LOG_INFO self._logger.setLevel(self.loglevel) def info(self, msg): self._logger.info(str(msg)) def debug(self, msg): self._logger.debug(str(msg)) def warn(self, msg): self._logger.warn(str(msg)) def error(self, msg): self._logger.error(str(msg)) def write(self, msg): self.info(msg)
class BasicLogger(object): def __init__(self, loglevel=LOG_DEBUG, servicename='fshttpstream'): self.loglevel = loglevel h = logging.StreamHandler() h.setLevel(loglevel) fmt = logging.Formatter("%(asctime)s " + servicename + "[%(process)d]: %(levelname)s: %(message)s") h.setFormatter(fmt) self._logger = RootLogger(loglevel) self._logger.addHandler(h) def set_debug(self): self.loglevel = LOG_DEBUG self._logger.setLevel(self.loglevel) def set_info(self): self.loglevel = LOG_INFO self._logger.setLevel(self.loglevel) def info(self, msg): self._logger.info(str(msg)) def debug(self, msg): self._logger.debug(str(msg)) def warn(self, msg): self._logger.warn(str(msg)) def error(self, msg): self._logger.error(str(msg)) def write(self, msg): self.info(msg)
class StdoutLogger(object): def __init__(self, loglevel=LOG_DEBUG, servicename=__default_servicename__): self.loglevel = loglevel h = logging.StreamHandler() h.setLevel(loglevel) fmt = logging.Formatter("%(asctime)s " + servicename + "[%(process)d]: %(levelname)s: %(message)s") h.setFormatter(fmt) self._logger = RootLogger(loglevel) self._logger.addHandler(h) def set_debug(self): self.loglevel = LOG_DEBUG self._logger.setLevel(self.loglevel) def set_info(self): self.loglevel = LOG_INFO self._logger.setLevel(self.loglevel) def set_error(self): self.loglevel = LOG_ERROR self._logger.setLevel(self.loglevel) def set_warn(self): self.loglevel = LOG_WARN self._logger.setLevel(self.loglevel) def info(self, msg): self._logger.info(safe_str(msg)) self.hook(msg, 'info') def debug(self, msg): self._logger.debug(safe_str(msg)) self.hook(msg, 'debug') def warn(self, msg): self._logger.warn(safe_str(msg)) self.hook(msg, 'warn') def error(self, msg): self._logger.error(safe_str(msg)) self.hook(msg, 'error') def write(self, msg): self.info(msg) def hook(self, msg, levelname): pass
class HTTPLogger(object): def __init__(self, url, method='POST', fallback_file=None, loglevel=LOG_DEBUG, servicename=__default_servicename__): import urlparse self.loglevel = loglevel self.fallback_file = fallback_file p = urlparse.urlparse(url) netloc = p.netloc urlpath = p.path if p.query: urlpath += '?' + query h = HTTPHandler(host=netloc, url=urlpath, method=method) h.setLevel(loglevel) fmt = logging.Formatter(servicename+"[%(process)d]: %(levelname)s: %(message)s") h.setFormatter(fmt) self._logger = RootLogger(loglevel) self._logger.addHandler(h) if self.fallback_file: self._fallback = FileLogger(logfile=self.fallback_file, loglevel=self.loglevel, servicename=servicename) else: self._fallback = DummyLogger() def set_debug(self): self.loglevel = LOG_DEBUG self._logger.setLevel(self.loglevel) self._fallback.set_debug() def set_info(self): self.loglevel = LOG_INFO self._logger.setLevel(self.loglevel) self._fallback.set_info() def set_error(self): self.loglevel = LOG_ERROR self._logger.setLevel(self.loglevel) self._fallback.set_error() def set_warn(self): self.loglevel = LOG_WARN self._logger.setLevel(self.loglevel) self._fallback.set_warn() def info(self, msg): try: self._logger.info(safe_str(msg)) except: self._fallback.info(safe_str(msg)) def debug(self, msg): try: self._logger.debug(safe_str(msg)) except: self._fallback.debug(safe_str(msg)) def warn(self, msg): try: self._logger.warn(safe_str(msg)) except: self._fallback.warn(safe_str(msg)) def error(self, msg): try: self._logger.error(safe_str(msg)) except: self._fallback.error(safe_str(msg)) def write(self, msg): try: self.info(msg) except: self._fallback.info(safe_str(msg))
class HTTPLogger(object): def __init__(self, url, method='POST', fallback_file=None, loglevel=LOG_DEBUG, servicename=__default_servicename__): import urlparse self.loglevel = loglevel self.fallback_file = fallback_file p = urlparse.urlparse(url) netloc = p.netloc urlpath = p.path if p.query: urlpath += '?' + query h = HTTPHandler(host=netloc, url=urlpath, method=method) h.setLevel(loglevel) fmt = logging.Formatter(servicename + "[%(process)d]: %(levelname)s: %(message)s") h.setFormatter(fmt) self._logger = RootLogger(loglevel) self._logger.addHandler(h) if self.fallback_file: self._fallback = FileLogger(logfile=self.fallback_file, loglevel=self.loglevel, servicename=servicename) else: self._fallback = DummyLogger() def set_debug(self): self.loglevel = LOG_DEBUG self._logger.setLevel(self.loglevel) self._fallback.set_debug() def set_info(self): self.loglevel = LOG_INFO self._logger.setLevel(self.loglevel) self._fallback.set_info() def set_error(self): self.loglevel = LOG_ERROR self._logger.setLevel(self.loglevel) self._fallback.set_error() def set_warn(self): self.loglevel = LOG_WARN self._logger.setLevel(self.loglevel) self._fallback.set_warn() def info(self, msg): try: self._logger.info(safe_str(msg)) except: self._fallback.info(safe_str(msg)) def debug(self, msg): try: self._logger.debug(safe_str(msg)) except: self._fallback.debug(safe_str(msg)) def warn(self, msg): try: self._logger.warn(safe_str(msg)) except: self._fallback.warn(safe_str(msg)) def error(self, msg): try: self._logger.error(safe_str(msg)) except: self._fallback.error(safe_str(msg)) def write(self, msg): try: self.info(msg) except: self._fallback.info(safe_str(msg))