!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache/2.2.16 (Debian). PHP/5.3.3-7+squeeze19 

uname -a: Linux mail.tri-specialutilitydistrict.com 2.6.32-5-amd64 #1 SMP Tue May 13 16:34:35 UTC
2014 x86_64
 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/usr/share/pyshared/coherence/extern/   drwxr-xr-x
Free 129.99 GB of 142.11 GB (91.47%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     logger.py (6.38 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
# Licensed under the MIT license
# http://opensource.org/licenses/mit-license.php

# Copyright 2006, Frank Scholz <coherence@beebits.net>

import os, sys
#import logging

from twisted.python import log

LOG_UNSET       =  0
LOG_DEBUG       = 10
LOG_INFO        = 20
LOG_WARNING     = 30
LOG_ERROR       = 40
LOG_CRITICAL    = 50
LOG_NONE        = 100

log_levels = { 'info': LOG_INFO,
               'debug': LOG_DEBUG,
               'warning': LOG_WARNING,
               'error': LOG_ERROR,
               'critical': LOG_CRITICAL,
               'none': LOG_NONE}

class _Logger(object):
    """ a singleton LOG class
    """

    def __new__(cls, *args, **kwargs):
        obj = getattr(cls,'_instance_',None)
        if obj is not None:
            return obj
        else:
            obj = super(_Logger, cls).__new__(cls, *args, **kwargs)
            cls._instance_ = obj

            #logging.basicConfig(level=logging.INFO,
            #                    format='%(asctime)s %(message)s',
            #                    datefmt='%d %b %Y %H:%M:%S',)
            #obj.log = logging.getLogger('.')
            #obj.log.setLevel(logging.INFO)
            obj.feeds = {}
            obj.master_level = None
            return obj

    def __init__(self,name='',level=LOG_DEBUG):
        """ a LOG feed registers with us """
        if not self.feeds.has_key(name):
            if self.master_level:
                level = self.master_level
            self.feeds[name] = {'active':True,'level':level}

    def start_logging(self, logfile=None):
            if logfile is not None:
                observer = log.FileLogObserver(open(logfile, 'w'))
            else:
                observer = log.FileLogObserver(sys.stdout)
            log.startLoggingWithObserver(observer.emit, setStdout=0)

    def send(self, name, level, *args):
        try:
            if self.feeds[name]['active'] == False:
                return
            if level >= self.feeds[name]['level']:
                a = []
                for i in args:
                    if isinstance(i,unicode):
                        i = i.encode('ascii', 'ignore')
                    else:
                        i = str(i)
                    a.append(i)
                msg = ' '.join(a)
                log.msg('%s: %s' % (name, msg))
        except KeyError:
            log.msg("Logger error, feed %s not found" % name)

    def enable(self, name):
        try:
            self.feeds[name]['active'] = True
        except KeyError:
            self.feeds[name] = {'active':True,'level':LOG_DEBUG}

    def disable(self, name):
        try:
            self.feeds[name]['active'] = False
        except KeyError:
            self.feeds[name] = {'active':False,'level':LOG_DEBUG}

    def set_level(self, name, level):
        try:
            self.feeds[name]['level'] = level
        except KeyError:
            self.feeds[name] = {'active':False,'level':level}

    def get_level(self, name):
        try:
            return self.feeds[name]['level']
        except KeyError:
            return None

    def set_master_level(self,level):
        self.master_level = level
        for feed in self.feeds.values():
            feed['level'] = level

class Logger:

    def __init__(self, name='', level=LOG_DEBUG):
        self.name = name
        self.log = _Logger(name,level)

    def start_logging(self, logfile=None):
        self.log.start_logging(logfile)

    def send(self, level, *args):
        self.log.send( self.name, LOG_UNSET, *args)

    def msg(self, *args):
        self.log.send( self.name, LOG_DEBUG, *args)

    def info(self, *args):
        self.log.send( self.name, LOG_INFO, *args)

    def debug(self, *args):
        self.log.send( self.name, LOG_DEBUG, *args)

    def warning(self, *args):
        self.log.send( self.name, LOG_WARNING, *args)

    def error(self, *args):
        self.log.send( self.name, LOG_ERROR, *args)

    def critical(self, *args):
        self.log.send( self.name, LOG_CRITICAL, *args)

    def enable(self, name=None):
        if name == None:
            name=self.name
        self.log.enable(name)

    def disable(self, name=None):
        if name == None:
            name=self.name
        self.log.disable(name)

    def set_level(self, name=None, level=LOG_INFO):
        if name == None:
            name=self.name
        if isinstance( level, str):
            try:
                level=log_levels[level]
            except:
                level=LOG_INFO
        self.log.set_level(name,level)

    def get_level(self, name=None):
        if name == None:
            name=self.name
        return self.log.get_level(name)

    def has_level(self, level, name=None):
        if name == None:
            name=self.name
        if self.log.get_level(name) <= level:
            return True
        else:
            return False

    def set_warning_level(self, name=None):
        if name == None:
            name=self.name
        self.log.set_level(name,LOG_WARNING)

    def set_critical_level(self, name=None):
        if name == None:
            name=self.name
        self.log.set_level(name,LOG_CRITICAL)

    def set_master_level(self, level=LOG_DEBUG):
        if isinstance( level, str):
            try:
                level=log_levels[level]
            except:
                level=LOG_DEBUG
        self.log.set_master_level(level)

    def overwrite(self,name,level=None,active=None):
        if level:
            self.log.set_level(name,level)
        if active != None:
            if active == True:
                self.log.enable(name)
            else:
                self.log.disable(name)

    def get_feeds(self):
        return self.log.feeds()

if __name__ == '__main__':

    from twisted.internet import reactor

    def test1():
        l1 = Logger('Test 1')
        l1.send( 'Dies', 'ist', 'ein', 'Send', 'Test')
        l1.info( 'Dies', 'ist', 'ein', 'Info', 'Test')

        l2 = Logger('Test 2')
        l2.info( 'Dies', 'ist', 'ein', 'Info', 'Test')

        l3 = Logger('Test 3')
        l3.error( 'Dies', 'ist', 'ein', 'Error', 'Test')
        l2.disable(name='Test 1')

        l1.info( 'Dies', 'ist', 'ein', 'Info', 'Test')

        l2.enable(name='Test 1')

        l1.info( 'Dies', 'ist', 'ein', 'Info', 'Test')

        l3.set_level(name='Test 1',level=LOG_ERROR)

        l1.info( 'Dies', 'ist', 'ein', 'Info', 'Test')
        l1.error( 'Dies', 'ist', 'ein', 'Error', 'Test')

    reactor.callWhenRunning( test1)

    reactor.run()

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by KaizenLouie | C99Shell Github | Generation time: 0.0089 ]--